PHP는 널리 사용되는 서버 측 스크립팅 언어로서 민감한 데이터를 처리할 때 데이터 보안을 보장하기 위해 데이터 암호화 및 암호 해독이 필요합니다. 이 기사에서는 PHP가 데이터 암호화 및 암호 해독을 수행하는 방법을 소개합니다.
(1) AES 키 생성:
$key = random_bytes(32); // 生成一个32字节长的随机密钥
(2) 데이터 암호화:
$data = "敏感数据"; $encrypted = openssl_encrypt($data, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv); // 加密数据 $iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length('AES-256-CBC')); // 生成一个随机的初始向量
(3) 데이터 해독:
$decrypted = openssl_decrypt($encrypted, 'AES-256-CBC', $key, OPENSSL_RAW_DATA, $iv); // 解密数据
(1) RSA 키 쌍 생성:
$config = array( "digest_alg" => "sha512", "private_key_bits" => 4096, "private_key_type" => OPENSSL_KEYTYPE_RSA, ); $res = openssl_pkey_new($config); // 生成RSA密钥对 openssl_pkey_export($res, $privateKey); // 导出私钥 $publicKey = openssl_pkey_get_details($res)['key']; // 获取公钥
(2) 데이터 암호화:
$data = "敏感数据"; openssl_public_encrypt($data, $encrypted, $publicKey); // 使用公钥加密数据
(3) 데이터 해독:
openssl_private_decrypt($encrypted, $decrypted, $privateKey); // 使用私钥解密数据
(1) 원본 데이터의 해시 계산:
$data = "原始数据"; $hash = md5($data); // 计算MD5哈希值 $hash = sha1($data); // 计算SHA1哈希值 $hash = hash('sha256', $data); // 计算SHA256哈希值
(2) 해시 값 확인:
$hash = "存储的哈希值"; if (md5($data) === $hash) { echo "哈希值一致"; } else { echo "哈希值不一致"; }
요약: PHP는 민감한 데이터 방법을 처리할 때 다양한 암호화 및 복호화 기능을 제공합니다. , 대칭 암호화 알고리즘, 비대칭 암호화 알고리즘 및 해시 알고리즘을 포함합니다. 개발자는 실제 요구 사항에 따라 데이터 보안을 보호하기 위해 적절한 암호화 알고리즘을 선택할 수 있습니다.
위 내용은 PHP 데이터 암호화 및 복호화 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!