注意:由于获取的设备信息完全可以通过诸如hook拦截等手段伪造,因此不能简单通过代码获取到数据作为判断用户身份的唯一凭据!(某些apk竟然通过imsi,imei来为用户自动登录...)
private static String getUniqueID(Context paramContext)
{
for (;;)
{
byte[] arrayOfByte;
int i;
try
{
String str1 = ((TelephonyManager)paramContext.getSystemService("phone")).getDeviceId();
String str2 = "35" + Build.BOARD.length() % 10 + Build.BRAND.length() % 10 + Build.CPU_ABI.length() % 10 + Build.DEVICE.length() % 10 + Build.DISPLAY.length() % 10 + Build.HOST.length() % 10 + Build.ID.length() % 10 + Build.MANUFACTURER.length() % 10 + Build.MODEL.length() % 10 + Build.PRODUCT.length() % 10 + Build.TAGS.length() % 10 + Build.TYPE.length() % 10 + Build.USER.length() % 10;
String str3 = Settings.Secure.getString(paramContext.getContentResolver(), "android_id");
String str4 = ((WifiManager