用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]