首页 新闻 会员 周边

C# 3DES加密的key和JAVA的方式不对应

0
悬赏园豆:20 [待解决问题]

C# 3DES加密的key和JAVA的方式不对应

用C# 3DES加密,然后JAVA解密失败。不成功。看了下JAVA的加密源码,发现是加密时key值不同导致的。

C#的key值我是这样获取的:byte[] key = Encoding.Default.GetBytes(“key”);
byte[] key = Encoding.UTF8.GetBytes("key");
byte[] key = ASCIIEncoding.ASCII.GetBytes("key");
(这三个方法结果相同,所以不是这的问题);
byte[] a1 = new byte[24];
Array.Copy(miyao, a1, 24);
这句是为了取数组的前24位,得到的数组我们命名为A,稍后给出。

JAVA的key值是这样获取的:
byte[] key = “key”.getBytes();
DESedeKeySpec spec = new DESedeKeySpec(key); //这句同样也是为了取byte数组的前24位,这句运行后的结果和C#等同
Key key = SecretKeyFactory.getInstance("DESede").generateSecret(spec ); //经过这一行后,byte数组的值就变化了,我们把它命名为B。查了资料:根据提供的密钥规范(密钥材料)生成

SecretKey 对象。不知道这一行是什么逻辑,用C#怎么转换。

A:[100, 55, 50, 50, 52, 53, 98, 97, 51, 50, 99, 101, 52, 99, 54, 55, 97, 102, 102, 54, 56, 57, 52, 50]
B:[100, 55, 50, 50, 52, 52, 98, 97, 50, 50, 98, 100, 52, 98, 55, 55, 97, 103, 103, 55, 56, 56, 52, 50]

类似于红色部分,有的值会变,不知道什么原则。

irfanchen的主页 irfanchen | 初学一级 | 园豆:100
提问于:2016-03-10 10:45
< >
分享
所有回答(2)
0

java中的3des和.net中的3des是有些不一致,这个最好查下

Daniel Cai | 园豆:10424 (专家六级) | 2016-03-10 11:47

哪里不一致?

支持(0) 反对(0) irfanchen | 园豆:100 (初学一级) | 2016-03-10 13:44
0

猜测是java里面大公整型的 bigInt 的原因,在DES算法里,也会出现类似情况,查查资料吧.

当时做DES的解决方案是,把jar包转dll,直接使用dll做加解密

Sky.Grain | 园豆:308 (菜鸟二级) | 2016-03-10 13:21

@irfanchen:  JAVA 里面的一个数据类型 BigInteger 理论上来说,只要内存够大,可以放无限大的数字,

在用java 做这种加密算法的时候经常用到,这个类型对应的C#的一些版本里面是没有的

以前做DES加密的时候遇到过这个情况,你这个情况是猜测这个原因,但不确定。

支持(0) 反对(0) Sky.Grain | 园豆:308 (菜鸟二级) | 2016-03-10 13:42

@Sky.Grain: 我没有用到BigInteger 这个类型的

支持(0) 反对(0) irfanchen | 园豆:100 (初学一级) | 2016-03-10 13:45

@irfanchen: 想用的话,出个jar包转dll吧,以前试过,也挺好用的,网上有方法

支持(0) 反对(0) Sky.Grain | 园豆:308 (菜鸟二级) | 2016-03-10 13:46

@Sky.Grain: 我只能修改我的加密方法,对方的解密方式我不能修改

支持(0) 反对(0) irfanchen | 园豆:100 (初学一级) | 2016-03-10 13:48

@irfanchen: 因为加密算法里面有一个偏移向量会出现差异的问题,如果卡在这里的话,就不清楚怎么解决了。对方如果能出一个完整 3DES 加解密的jar包的可以保持统一的方式

支持(0) 反对(0) Sky.Grain | 园豆:308 (菜鸟二级) | 2016-03-10 13:51

@Sky.Grain: 我现在知道对方的加解密源码,看过之后就发现因为最后那一行,导致key值不一样了,没经过那一行值都相同

支持(0) 反对(0) irfanchen | 园豆:100 (初学一级) | 2016-03-10 13:54
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册