- 102浏览
- 2022-06-09
<?php
class Encryption {
private $key;
public function __construct($key) {
$this->key = $key;
}
public function encrypt($data) {
$iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length('aes-256-cbc'));
$encrypted = openssl_encrypt($data, 'aes-256-cbc', $this->key, 0, $iv);
return base64_encode($encrypted . '::' . $iv);
}
public function decrypt($data) {
$data = base64_decode($data);
list($encrypted_data, $iv) = explode('::', $data, 2);
return openssl_decrypt($encrypted_data, 'aes-256-cbc', $this->key, 0, $iv);
}
}
// 使用示例
$encryption = new Encryption('my_secret_key');
$encrypted_data = $encryption->encrypt('Hello World');
echo "加密后的数据:$encrypted_data\n";
$decrypted_data = $encryption->decrypt($encrypted_data);
echo "解密后的数据:$decrypted_data\n";
?>
在上面的代码中,我们定义了一个名为Encryption的类,它有两个方法:encrypt和decrypt。encrypt方法接受一个字符串参数,使用AES-256-CBC算法和一个随机生成的IV对数据进行加密,并返回一个Base64编码的字符串。decrypt方法接受一个加密后的字符串参数,解码它并使用相同的密钥和IV对数据进行解密,然后返回原始字符串。
请注意,这只是一个简单的示例,实际上,加密和解密数据需要更多的安全措施和最佳实践。
版权声明:
1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。
2、本站仅提供信息发布平台,不承担相关法律责任。
3、若侵犯您的版权或隐私,请联系本站管理员删除。
4、本文由会员转载自互联网,如果您是文章原创作者,请联系本站注明您的版权信息。