3DES加密-android和java之间的差异
发布日期:2021-10-10 05:31:06 浏览次数:10 分类:技术文章

本文共 1005 字,大约阅读时间需要 3 分钟。

项目中使用3DES搭配RSA进行加密,完成网络密文传输功能.

在加密过程中,由于android跟java平台有些差异,导致加、解密存在一些问题;

1.秘钥获取问题

java平台获取3DES秘钥的方法,其中eccryptKey是秘钥字符串;

// 获取秘钥
public SecretKey getSecretKey() {
SecretKey deskey = null;
KeyGenerator kg = null;
try {
kg = KeyGenerator.getInstance("DESede");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
kg.init(168, new SecureRandom(encryptKey.getBytes()));
SecretKey secretKey = kg.generateKey();
deskey = new SecretKeySpec(secretKey.getEncoded(), "DESede");
return deskey;
}

使用秘钥加密的核心代码

上述代码在java平台运行加解密正常,但是在android平台加解密会失败;

原因是KeyGgenerator和SecureRandom两个类,在java和android中的Provider是不一样的,导致生成的SecretKey不一样,秘钥不一样,自然解密会失败。

解决方案是:将获取秘钥方案修改为

// 获取秘钥
public SecretKey getSecretKey() {
SecretKey deskey = null;
deskey = new SecretKeySpec(encryptKey.getBytes(), "DESede");
return deskey;
}

即不使用上述两个类,直接使用encryptKey来生成秘钥,不过这种方案对秘钥的长度有限制,android平台限制长度为16或者24,java平台使用16位,会提示key size wrong,所以,秘钥长度应设置为24位。

2.解析问题:

解析过程中,出现乱码,需将解析后的字符串使用Base64编码一次,解码一次。使用Base64时,应注意java平台和android平台的BASE64工具是有差别的!

转载地址:https://blog.csdn.net/qq_22054203/article/details/97274620 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:京东开源超大规模联邦学习平台(9NFL) 深度连接合作伙伴
下一篇:解决github提交时,403错误!

发表评论

最新留言

哈哈,博客排版真的漂亮呢~
[***.191.171.1]2022年12月07日 11时16分42秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

最新文章