PHP encrpyt, первые 16 строк после расшифровки с помощью Python - PullRequest
0 голосов
/ 08 мая 2019

После шифрования с помощью PHP 7, всякий раз, когда я расшифровываю с помощью Python 2, первые 16 символов пропадают ..

IE:

до шифрования:

ЭТО ТЕКСТЭТО должно быть зашифровано, а также должно быть расшифровано с использованием PYTHON (или другого языка).

после дешифрования:

не должно быть зашифровано и также должно быть расшифровано с использованием PYTHON (или другого)ЯЗЫК)

PHP для шифрования

$method = 'AES-256-CBC';

$key = hash('sha256', 'password', true);

$ivlen = openssl_cipher_iv_length($method);

$iv = openssl_random_pseudo_bytes($ivlen);

$enc = openssl_encrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv);

$encrypted = base64_encode($enc);

Python для расшифровки

import base64
import hashlib
from Crypto import Random
from Crypto.Cipher import AES

class SomeClass(object):

    def __init__(self, key): 
        self.bs = 32
        self.key = hashlib.sha256(key.encode()).digest()

    def decrypt(self, enc):
        enc = base64.b64decode(enc)
        iv = enc[:AES.block_size]
        cipher = AES.new(self.key, AES.MODE_CBC, iv)
        return self._unpad(cipher.decrypt(enc[AES.block_size:])).decode('utf-8')

    def _pad(self, s):
        return s + (self.bs - len(s) % self.bs) * chr(self.bs - len(s) % self.bs)

    @staticmethod
    def _unpad(s):
        return s[:-ord(s[len(s)-1:])]

, поэтому, если я зашифрую это вPHP (расшифровка на PHP работает нормально)

ЭТОТ ТЕКСТ, КОТОРЫЙ НЕОБХОДИМО ШИФРОВАТЬ И ТАКЖЕ ДОЛЖЕН БЫТЬ ДЕЙСТВОВАТЬ С ПОМОЩЬЮ PYTHON (ИЛИ ДРУГОГО ЯЗЫКА).

, но я расшифровал его на Pythonрезультат пропускает первые 16 частей строки

, которые должны быть зашифрованы, а также должны быть расшифрованы с использованием питона (или другого языка)

...