我有一个使用CryptoJS的js DES加密代码,如下所示:
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)
请帮帮我。
发布于 2020-11-01 03:26:41
基于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))
仅供参考。
https://stackoverflow.com/questions/64625070
复制相似问题