Android设备唯一性判断

前段时间项目需要一个功能,就是在操作完某一个逻辑之后返回给客户一个红包,安全校验团队需要我们提供android设备的唯一标示,起初直接通过获取设备的imei号传给了server端,后台公司云迹监控发现,有些设备的imei号是0000000000000000,这样失去了设备唯一性验证的功能,第二个版本做了一个修复,除了获取imei号之外还新增了AndrdoiId的处理,不过悲剧的是android 设备实在是太多太杂了,仅仅通过这两个维度去确定设备的唯一性还是有一些漏洞的,最终我们的解决方案是尽量多的获取与设备相关的信息,最后做一个MD5数字加签,基本满足了这个需求

[java] view plaincopy
  1. package com.suning.mobile.epa;
  2. import java.security.MessageDigest;
  3. import java.security.NoSuchAlgorithmException;
  4. import android.content.Context;
  5. import android.os.Build;
  6. import android.provider.Settings.Secure;
  7. import android.telephony.TelephonyManager;
  8. public class DeviceFactoty {
  9. // buildId
  10. public String m_szDevIDShortMaker() {
  11. String m_szDevIDShort = "35";
  12. m_szDevIDShort += Build.BOARD.length() % 10 + Build.BRAND.length() % 10
  13. + Build.CPU_ABI.length() % 10 + Build.DEVICE.length() % 10
  14. + Build.DISPLAY.length() % 10 + Build.HOST.length() % 10
  15. + Build.ID.length() % 10 + Build.MANUFACTURER.length() % 10
  16. + Build.MODEL.length() % 10 + Build.PRODUCT.length() % 10
  17. + Build.TAGS.length() % 10 + Build.TYPE.length() % 10
  18. + Build.USER.length() % 10 + "";
  19. return m_szDevIDShort;
  20. }
  21. public String currentDeviceMark(Context context) {
  22. final TelephonyManager tm = (TelephonyManager) context
  23. .getSystemService(Context.TELEPHONY_SERVICE);
  24. final String tmDevice, tmSerial, androidId;
  25. tmDevice = "" + tm.getDeviceId();
  26. tmSerial = "" + tm.getSimSerialNumber();
  27. androidId = ""
  28. + android.provider.Settings.Secure.getString(EPApp.getApp()
  29. .getContentResolver(), Secure.ANDROID_ID);
  30. String serial = "";
  31. if (Build.VERSION.SDK_INT > Build.VERSION_CODES.FROYO){
  32. serial = Build.SERIAL;
  33. }
  34. String m_szLongID = tmDevice + tmSerial + androidId + serial
  35. + m_szDevIDShortMaker();
  36. MessageDigest m = null;
  37. try {
  38. m = MessageDigest.getInstance("MD5");
  39. } catch (NoSuchAlgorithmException e) {
  40. e.printStackTrace();
  41. }
  42. m.update(m_szLongID.getBytes(), 0, m_szLongID.length());
  43. // get md5 bytes
  44. byte p_md5Data[] = m.digest();
  45. // create a hex string
  46. String m_szUniqueID = new String();
  47. for (int i = 0; i < p_md5Data.length; i++) {
  48. int b = (0xFF & p_md5Data[i]);
  49. // if it is a single digit, make sure it have 0 in front (proper padding)
  50. if (b <= 0xF)
  51. m_szUniqueID += "0";
  52. // add number to string
  53. m_szUniqueID += Integer.toHexString(b);
  54. } // hex string to uppercase
  55. return m_szUniqueID = m_szUniqueID.toUpperCase();
  56. }
  57. }
上一篇:PhpStorm 的快捷键


下一篇:【转】 不需要任何权限获得Android设备的唯一ID