pyCrypto: длина ввода должна быть кратна 16 - PullRequest
0 голосов
/ 05 сентября 2018

Я пытаюсь расшифровать строку, закодированную с помощью "crypto-js", и расшифровать ее в python, используя "pyCrypto". Я следовал за точными шагами на различных блогах, но все еще та же самая ошибка.

Последнее сообщение от stackoverflow, за которым я следовал, было « CryptoJS и Pycrypto работают вместе », ответ @Artjom B.

Также пробовал "https://chase -seibert.github.io / blog / 2016/01/29 / cryptojs-pycrypto-ios-aes256.html "

Мой код JS

var pass = CryptoJS.AES.encrypt(text, password_encrypt_key, 
        {
            iv: password_encrypt_iv,
        })
    return password_encrypt_iv.concat(pass.ciphertext).toString(CryptoJS.enc.Base64);

А мой код на Python

    BLOCK_SIZE = 16
    KEY = constants.PASSWORD_ENCRYPT_KEY
    # IV = constants.PASSWORD_ENCRYPT_IV
    IV = enc_password[:BLOCK_SIZE]
    MODE = AES.MODE_CBC
    enc_password = base64.b64decode(enc_password)
    aes = AES.new(KEY, MODE, IV)
    password = unpad(aes.decrypt(enc_password[BLOCK_SIZE:]))

функция unpad

def unpad(s):
  return s[:-ord(s[-1])]

1 Ответ

0 голосов
/ 10 сентября 2018

Я нашел решение. Не уверен, как это работает, и не остальное решение, но в любом случае опубликовать его. Также решение от ответа ниже ссылки Artjom B. Он дал лучшее объяснение. Я также отправляю тот же ответ.

Ссылка - Как расшифровать пароль из JavaScript CryptoJS.AES.encrypt (пароль, пароль) в Python

Javascript -

var KEY = encrypt_key;
var encrypted_txt_obj = CryptoJS.AES.encrypt(text, KEY);
return encrypted_txt_obj.toString();

питон -

from Crypto.Cipher import AES
import base64

BLOCK_SIZE = 16

def bytes_to_key(data, salt, output=48):
    data += salt
    key = md5(data).digest()
    final_key = key
    while len(final_key) < output:
      key = md5(key + data).digest()
      final_key += key
    return final_key[:output]

def decrypt_text(enc):
    try:
        enc = base64.b64decode(enc)
        assert enc[0:8] == b"Salted__"
        salt = enc[8:16]
        key_iv = bytes_to_key(encrypt_key, salt, 32 + 16)
        key = key_iv[:32]
        iv = key_iv[32:]
        aes = AES.new(key, AES.MODE_CBC, iv)
        text = unpad(aes.decrypt(enc[16:]))
        return text
   except Exception as e:
        resp = jsonify({constants.ERR_SERVER: e.message})
        resp.status_code = 403
        logger.error("Exception %s", e.message)
        return resp

def unpad(data):
    return data[:-(data[-1] if type(data[-1]) == int else ord(data[-1]))]
...