我有一个js DES加密代码,使用CryptoJS如下:
const CryptoJS = require('crypto-js');
function encryptByDES(message, key) {
var keyHex = CryptoJS.enc.Utf8.parse(key);
var encrypted = CryptoJS.DES.encrypt(message, keyHex, {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
return encrypted.toString();
}
,如果输入message="123456789", key="123456abcdefghijklmnopqrstuvwxyz"
,则输出为J6cwLeYoidP5U1V6MT67Ig==
。
我想知道代码的Python3版本。我试过PyCrytodome并没有运气(对此软件包我不太了解),最近的代码如下:
from Crypto.Util.Padding import pad, unpad
from Crypto.Cipher import DES
from Crypto.Random import get_random_bytes
import binascii
data = b'123456789'
key = b'123456abcdefghijklmnopqrstuvwxyz'
iv = get_random_bytes(16)
# below line triggers error
cipher1 = DES.new(key, DES.MODE_CFB, iv)
ct = cipher1.encrypt(pad(data, 16))
print(binascii.b2a_base64(ct))
错误是
ValueError: Incorrect DES key length (32 bytes)
请帮帮我。
答案 0 :(得分:0)
根据Topaco的建议,终于可以使用了,代码如下:
data = b'123456789'
# the next cdefghijklmnopqrstuvwxyz is no needed
key = b'123456ab'
cipher = DES.new(key, DES.MODE_ECB)
ct = cipher.encrypt(pad(data, 8))
print(binascii.b2a_base64(ct))
仅供参考。