
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 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
哈哈,博客排版真的漂亮呢~
[***.191.171.1]2022年12月07日 11时16分42秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
最新文章
Python基础(2):控制结构
2019-06-18 13:17:57
POJ1064:Cable master(二分)
2019-06-18 13:17:57
Ubuntu安装python3虚拟环境
2019-06-18 13:17:56
JS--DOM
2019-06-18 13:17:56
C语言文件操作
2019-06-18 13:17:55
未授权访问整理
2019-06-18 13:17:55
博客更换
2019-06-18 13:17:54
Ubuntu16.04安装网易云音乐
2019-06-18 13:17:54
jQuery $.each用法
2019-06-18 13:17:53
xcode工程编译错误:The maximum number of apps for free development profiles has been reached.
2019-06-18 13:17:53
[转] 为你的项目选择一个合适的开源协议
2019-06-18 13:17:52
springMVC---servletAPI
2019-06-18 13:17:52
20165306 Exp9 Web安全基础
2019-06-18 13:17:50
js获取url,截取url参数,截取url后文件名
2019-06-18 13:17:50
Flutter视图基础简介--Widget、Element、RenderObject
2019-06-18 13:17:49
如何实现在已有代码之后添加逻辑之继承,组合(静态代理)实现方法
2019-06-18 13:17:49
[HAOI2007]上升序列
2019-06-18 13:17:48
剑指Offer:第一个只出现一次的字符
2019-06-18 13:17:48
普通web项目转maven项目
2019-06-18 13:17:47
JdbcTemplate简单介绍
2019-06-18 13:17:46