PHP 는 openssl 기반 비대 칭 암호 화 코드 인 스 턴 스 를 실현 합 니 다.
1.openssl 과 phop 를 설치 한 openssl 확장
2.비밀 키 생 성:openssl genrsa 는 rsa 비밀 키 파일 을 생 성 하 는 데 사 용 됩 니 다.생 성 은 비밀 키 길이 와 비밀번호 보 호 를 지정 할 수 있 습 니 다.
openssl genrsa -out rsa_private_key.pem 1024
3.공개 키 생 성:rsa 명령 은 RSA 키,형식 변환,인쇄 정 보 를 처리 하 는 데 사 용 됩 니 다.openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
4.비밀 키 암호 화,공개 키 복호화 사용
<?php
/**
*
*/
$privateKeyFilePath = 'rsa_private_key.pem';
/**
*
*/
$publicKeyFilePath = 'rsa_public_key.pem';
extension_loaded('openssl') or die('php openssl ');
(file_exists($privateKeyFilePath) && file_exists($publicKeyFilePath)) or die(' ');
/**
* Resource , ,openssl_pkey_get_private false
*/
$privateKey = openssl_pkey_get_private(file_get_contents($privateKeyFilePath));
/**
* Resource , ,openssl_pkey_get_public false
*/
$publicKey = openssl_pkey_get_public(file_get_contents($publicKeyFilePath));
($privateKey && $publicKey) or die(' ');
/**
*
*/
$originalData = ' hahahaha';
/**
* ,
*/
$encryptData = '';
echo ' :', $originalData, PHP_EOL;
/////////////////////////////// ////////////////////////
if (openssl_private_encrypt($originalData, $encryptData, $privateKey)) {
/**
* base64_encode
*/
echo ' , (base64_encode ) :', base64_encode($encryptData), PHP_EOL;
} else {
die(' ');
}
/////////////////////////////// ////////////////////////
/**
*
*/
$decryptData = '';
if (openssl_public_decrypt($encryptData, $decryptData, $publicKey)) {
echo ' , :', $decryptData, PHP_EOL;
} else {
die(' ');
}
이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Laravel - 변환된 유효성 검사 규칙으로 API 요청 제공동적 콘텐츠를 위해 API를 통해 Laravel CMS에 연결하는 모바일 앱(또는 웹사이트) 구축을 고려하십시오. 이제 앱은 CMS에서 번역된 콘텐츠를 받을 것으로 예상되는 다국어 앱이 될 수 있습니다. 일반적으로 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.