gpt4 book ai didi

java - Java 中的 DESede 和 Python 中的 3des

转载 作者:行者123 更新时间:2023-12-01 23:10:54 54 4
gpt4 key购买 nike

我在理解java和python的三重Des算法之间的概念时遇到问题。在 java 中,加密 key 的长度为 48 个字符,而在 python 中则不能应用相同的 key 。我尝试了提到的两个建议 here但它似乎不适用于任何一种方式。我无法解密python中java加密的字符串。 java中的代码如下:

    import java.security.spec.KeySpec;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESedeKeySpec;


public class SecretKeyEncryptionExample
{
private static final String FORMAT = "ISO-8859-1";
public static final String DESEDE_ENCRYPTION_SCHEME = "DESede";
private KeySpec ks;
private SecretKeyFactory skf;
private Cipher cipher;
SecretKey key;

public SecretKeyEncryptionExample()
throws Exception
{
String myEncryptionKey = "<48 chars long string>";

this.ks = new DESedeKeySpec(myEncryptionKey.getBytes("ISO-8859-1"));
this.skf = SecretKeyFactory.getInstance("DESede");
this.cipher = Cipher.getInstance("DESede");
this.key = this.skf.generateSecret(this.ks);
}

而在 python 中,如果我使用:

from pyDes import *
import hashlib
import base64
key1 = "<48 chars long key>".decode('hex')
data = "<Some encrypted strings>"
k = triple_des(key1, ECB, "\0\0\0\0\0\0\0\0", pad=None, padmode=PAD_PKCS5)
e = k.decrypt(data)
print e

我是按照给出的第一个建议here来做的但它什么也没打印。我再次尝试了同一页面中的第二个建议,该建议要求使用前 24 个字符作为键并忽略其余部分:

from pyDes import *
import hashlib
import base64
key1 = "<taking only first 24 chars long key>"
data = "<Some encrypted data>"
k = triple_des(key1, ECB, "\0\0\0\0\0\0\0\0", pad=None, padmode=PAD_PKCS5)
e = k.decrypt(data)
print e

但这也没有给我任何输出..我对所有这些研究感到困惑。请建议哪种方法是正确的,以及为什么我没有从其中任何一种方法中得到任何输出。谢谢..

最佳答案

据我所知,在你的Python脚本中,你正在进行十六进制解码。但是,在 Java 代码中,您将字符串本身转换为字节。

尝试如下:

String myEncryptionKey = "<48 chars long string>";
this.ks = new DESedeKeySpec(DatatypeConverter.parseHexBinary(myEncryptionKey));

此外,请确保完全指定密码算法以避免可移植性问题。所以替换:

Cipher.getInstance("DESede");

类似:

Cipher.getInstance("DESede/ECB/PKCS5Padding");

关于java - Java 中的 DESede 和 Python 中的 3des,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21982389/

54 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com