7

我正在尝试加密 Python 程序中的一些数据并将其保存,然后在 Java 程序中解密该数据。在 Python 中,我像这样加密它:

from Crypto.Cipher import AES
KEY = '12345678901234567890123456789012'

def encrypt(data):
    cipher = AES.new(KEY, AES.MODE_CFB)
    return cipher.encrypt(data)

在Java中,我像这样解密它:

import java.security.*;
import javax.crypto.*;
import javax.crypto.spec.SecretKeySpec;

public class Encryption {
    private static byte[] KEY = { '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '1', '2', '3', '4', '5', '6', '7',
        '8', '9', '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '0', '1', '2' };

    public static byte[] decrypt(byte[] data) throws NoSuchAlgorithmException, NoSuchPaddingException,
            InvalidKeyException, IllegalBlockSizeException, BadPaddingException {
        Cipher c = Cipher.getInstance("AES/CFB/NoPadding");
        Key key = new SecretKeySpec(KEY, "AES");
        c.init(Cipher.DECRYPT_MODE, key);
        return c.doFinal(data);
    }
}

但我明白了Exception in thread "main" java.security.InvalidKeyException: Illegal key size or default parameters。显然,我做错了什么。但是什么?

4

3 回答 3

6

您遇到问题的原因是安全策略将您的密钥大小限制为 128 位,并且您尝试使用 256 位密钥(需要 Java 加密扩展 (JCE) 无限强度管辖权策略文件)。

看看这个讨论,你可能会注意到你有一个类似的问题。我实际上在我的机器上遇到了同样的问题。更新安全策略后,我能够运行您的代码。另外,我认为您应该进行以下更改c.init(Cipher.DECRYPT_MODE, key, new IvParameterSpec(new byte[16]));您缺少 CFB 模式的初始化向量。如果解密后的值不正确,请检查您初始化密钥的方式。

于 2012-05-04T02:20:03.847 回答
4

强烈建议为此使用跨语言加密 API。我是Keyczar的忠实粉丝,它恰好有 Java 和 Python 库。API 非常简单:

public String encrypt(String data)
public String decrypt(String data)

JavaPython中。

于 2012-05-03T23:45:44.433 回答
1
  • Python 2 字符串文字,如 'abc' 和 "abc" 是 ASCII。
  • 像 u'abc' 和 u"abc" 这样的 Python 2 字符串文字是 unicode。
  • Python 3 字符串文字,如 'abc' 和 "abc" 是 unicode。
  • Python 3 字符串文字,如 b'abc' 和 b"abc" 是字节类型。

Java 默认使用 unicode,类似于 Python 3。

对于跨语言、可互操作的加密,您可以查看https://code.google.com/p/keyczar/。该页面上有其使用的简单示例。

于 2012-05-03T23:46:38.153 回答