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]
类似于红色部分,有的值会变,不知道什么原则。
java中的3des和.net中的3des是有些不一致,这个最好查下
哪里不一致?
猜测是java里面大公整型的 bigInt 的原因,在DES算法里,也会出现类似情况,查查资料吧.
当时做DES的解决方案是,把jar包转dll,直接使用dll做加解密
@irfanchen: JAVA 里面的一个数据类型 BigInteger 理论上来说,只要内存够大,可以放无限大的数字,
在用java 做这种加密算法的时候经常用到,这个类型对应的C#的一些版本里面是没有的
以前做DES加密的时候遇到过这个情况,你这个情况是猜测这个原因,但不确定。
@Sky.Grain: 我没有用到BigInteger 这个类型的
@irfanchen: 想用的话,出个jar包转dll吧,以前试过,也挺好用的,网上有方法
@Sky.Grain: 我只能修改我的加密方法,对方的解密方式我不能修改
@irfanchen: 因为加密算法里面有一个偏移向量会出现差异的问题,如果卡在这里的话,就不清楚怎么解决了。对方如果能出一个完整 3DES 加解密的jar包的可以保持统一的方式
@Sky.Grain: 我现在知道对方的加解密源码,看过之后就发现因为最后那一行,导致key值不一样了,没经过那一行值都相同