gpt4 book ai didi

Python 中的 PHP openssl AES

转载 作者:可可西里 更新时间:2023-11-01 01:15:37 28 4
gpt4 key购买 nike

我正在从事一个使用 PHP 解密 AES-256-CBC 消息的项目

<?php

class CryptService{
private static $encryptMethod = 'AES-256-CBC';
private $key;
private $iv;

public function __construct(){
$this->key = hash('sha256', 'c7b35827805788e77e41c50df44441491098be42');
$this->iv = substr(hash('sha256', 'c09f6a9e157d253d0b2f0bcd81d338298950f246'), 0, 16);
}

public function decrypt($string){
$string = base64_decode($string);
return openssl_decrypt($string, self::$encryptMethod, $this->key, 0, $this->iv);
}

public function encrypt($string){
$output = openssl_encrypt($string, self::$encryptMethod, $this->key, 0, $this->iv);
$output = base64_encode($output);
return $output;
}
}

$a = new CryptService;
echo $a->encrypt('secret');
echo "\n";
echo $a->decrypt('S1NaeUFaUHdqc20rQWM1L2ZVMDJudz09');
echo "\n";

输出

>>> S1NaeUFaUHdqc20rQWM1L2ZVMDJudz09
>>> secret

现在我必须编写用于加密数据的 Python 3 代码。我试过使用 PyCrypto 但没有成功。我的代码:

import base64
import hashlib
from Crypto.Cipher import AES

class AESCipher:
def __init__(self, key, iv):
self.key = hashlib.sha256(key.encode('utf-8')).digest()
self.iv = hashlib.sha256(iv.encode('utf-8')).digest()[:16]

__pad = lambda self,s: s + (AES.block_size - len(s) % AES.block_size) * chr(AES.block_size - len(s) % AES.block_size)
__unpad = lambda self,s: s[0:-ord(s[-1])]

def encrypt( self, raw ):
raw = self.__pad(raw)
cipher = AES.new(self.key, AES.MODE_CBC, self.iv)
return base64.b64encode(cipher.encrypt(raw))

def decrypt( self, enc ):
enc = base64.b64decode(enc)
cipher = AES.new(self.key, AES.MODE_CBC, self.iv )
return self.__unpad(cipher.decrypt(enc).decode("utf-8"))

cipher = AESCipher('c7b35827805788e77e41c50df44441491098be42', 'c09f6a9e157d253d0b2f0bcd81d338298950f246')

enc_str = cipher.encrypt("secret")
print(enc_str)

输出

>>> b'tnF87LsVAkzkvs+gwpCRMg=='

但我需要输出 S1NaeUFaUHdqc20rQWM1L2ZVMDJudz09,它将 PHP 解密为 secret。如何修改 Python 代码以获得预期的输出?

最佳答案

PHP's hash默认情况下输出十六进制编码的字符串,但 Python 的 .digest() 返回 bytes。您可能想使用 .hexdigest():

def __init__(self, key, iv):
self.key = hashlib.sha256(key.encode('utf-8')).hexdigest()[:32].encode("utf-8")
self.iv = hashlib.sha256(iv.encode('utf-8')).hexdigest()[:16].encode("utf-8")

初始化向量 (IV) 的思想是为使用相同 key 的加密提供随机化。如果您使用相同的 IV,攻击者可能会推断出您发送了两次相同的消息。这可以被视为一个损坏的协议(protocol)。

IV 不应该是 secret 的,因此您可以简单地将它与密文一起发送。通常在加密期间将其附加到密文,并在解密之前将其切掉。

关于Python 中的 PHP openssl AES,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39690400/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com