java.security.InvalidKeyException: Key length not 128/192/256 bits.

原理:在设备首次启动时,系统会随机生成一个64位的数字,并把这个数字以16进制字符串的形式保存下来,这个16进制的字符串就是ANDROID_ID。而有些设备生成的数字为15位,是由于转化为16进制字符串的时候,去掉了前面的0。(如:部分魅族手机,获取的的设备号应该为“07129c5323b07a5f” ,可是使用代码获取的时候却省略了前面的0只得到了“7129c5323b07a5f”)。

原因分析:问题出现在获取android设备号时,android设备号不为16位字符串,只获取到了15位字符串,导致使用aes加密时出现InvalidKeyException异常。

byte[] key1 = AndroidUtility.getAndroidId(mContext).getBytes();
byte[] aesbyte = aes.encode(lpv.getPassword().toString().getBytes(), key1);

解决方法:只要把获取到的16进制字符串的android_id转化为十进制,然后再把得到的数字转化为16进制,即可得到正确的android_id。

 public static String getAndroidId(Context context) throws Exception {
    if (StringUtils.isEmpty(SECRET_ID)) {
         SECRET_ID = android.provider.Settings.Secure.getString(context.getContentResolver(),
                    android.provider.Settings.Secure.ANDROID_ID);
            Log.e("========android_ID===========", SECRET_ID);
            if (SECRET_ID.length() < 16) {
                long i1 = Long.valueOf(SECRET_ID, 16);
                SECRET_ID = String.format("%016x", i1);
            }
        }
        if (SECRET_ID.length() > 16) {
            Log.e("========android_ID===Error========", SECRET_ID);
            throw new Exception("ErrorAndroidID");
        }
        return SECRET_ID;
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值