English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية

PHP openssl_public_decrypt() 함수 사용법 및 예제

PHP OpenSSL 함수 매뉴얼

openssl_public_decrypt() 함수는 공개 키로 데이터를 복호화하는 데 사용됩니다.

정의와 사용법

openssl_public_decrypt()함수는 공개 키로 데이터를 복호화합니다.

openssl_private_encrypt()로 암호화된 데이터를 복호화하기 위해 openssl_public_decrypt() 함수를 사용합니다.

문법

openssl_public_decrypt ( string $data , string &$decrypted , mixed $key [, int $padding = OPENSSL_PKCS1_PADDING ] ) : bool

파라미터

순번파라미터描述
1

描述

data

2

使用openssl_private_encrypt()加密的数据。

decrypted

3

它将拥有解密的数据。

key

4

公钥。

padding1您可以应用的填充为:OPENSSL_PKCS

_PADDING,OPENSSL_NO_PADDING。

返回值

PHP openssl_public_decrypt()函数成功时返回TRUE,失败时返回FALSE。

PHP版本5此函数将从大于

Data decryption : Welcome To w1

.0.0的PHP版本开始工作。

示例
      // <?php
	保存私钥
	/xampp/htdocs/modules/openssl/openssl_pkey_export_to_file($privkey, 'C:'),
	//privatekey.pem');
	要使用openssl_private_encrypt()加密数据并使用openssl_public_decrypt()解密:3$data = 'Welcome To w
	$isvalid = openssl_private_encrypt($data, $crypted, file_get_contents('C:/xampp/htdocs/modules/openssl/privatekey.pem'),OPENSSL_PKCS1_PADDING);	
	echo "Data encryption : ".$crypted;
	echo "\>br"/<>br/<";
	//공개 키 저장
	$dn = array(
		"countryName" => "IN",
		"stateOrProvinceName" => "Karnataka",
		"localityName" => "test"1",
		"organizationName" => "test"2",
		"organizationalUnitName" => "test"3",
		"commonName" => "www.test.com",
		"emailAddress" => "[email protected]"
	);
	$cert = openssl_csr_new($dn, $privkey);
	$cert = openssl_csr_sign($cert, null, $privkey, 365);
	openssl_x509_export_to_file($cert, 'C:/xampp/htdocs/modules/openssl/publickey.pem');
	if ($isvalid) {	
		openssl_public_decrypt ($crypted, $decrypted , file_get_contents('C:/xampp/htdocs/modules/openssl/publickey.pem'),OPENSSL_PKCS1_PADDING);	
		echo "데이터 복호화: " . $decrypted;
	}
?>

이는 다음과 같은 결과를 생성합니다:

codebox.com';7Data encryption : k���G��3)xy{�N3Г�x<�J^�gd��Ψ�I?{��<�Ws9�mW$��h��(F;tJ�J�W��|�2L�vL��xF���f����,�(N�ΰ��n���Y%Oo,�-����Qh��G�|1�6����}���-Tm�qS�wb���[�i�8r�F��rQhZ���$�� ��U�pMC��Y�n�0,Z�CuG��4�h��@7f��
ؕ�w��;�����d���ʈ����$�I^�Z���at��?�3codebox.com

Data decryption : Welcome To w2

实例

示例
       //<?php
	保存私钥
	/xampp/htdocs/modules/openssl/openssl_pkey_export_to_file($privkey, 'C:'),
	//privatekey.pem');
	/xampp/htdocs/modules/openssl/$data = file_get_contents('C:'),
	$isvalid = openssl_private_encrypt($data, $crypted, file_get_contents('C:/xampp/htdocs/modules/openssl/privatekey.pem'),OPENSSL_PKCS1_PADDING);	
	echo "Data encryption : ".$crypted;
	echo "\>br"/<>br/<";
	//공개 키 저장
	$dn = array(
		"countryName" => "IN",
		"stateOrProvinceName" => "Karnataka",
		"localityName" => "test"1",
		"organizationName" => "test"2",
		"organizationalUnitName" => "test"3",
		"commonName" => "www.test.com",
		"emailAddress" => "[email protected]"
	);
	$cert = openssl_csr_new($dn, $privkey);
	$cert = openssl_csr_sign($cert, null, $privkey, 365);
	openssl_x509_export_to_file($cert, 'C:/xampp/htdocs/modules/openssl/publickey.pem');
	if ($isvalid) {	
		openssl_public_decrypt ($crypted, $decrypted , file_get_contents('C:/xampp/htdocs/modules/openssl/publickey.pem'),OPENSSL_PKCS1_PADDING);	
		echo "데이터 복호화: " . $decrypted;
	}
?>

이는 다음과 같은 결과를 생성합니다:

데이터 암호화: ��V*�+@4CҺX�i�mM6��� ���,?�F,��+�q �����@�������g�N6c<*eh��:������5Z��&�&'+= ���b���J�r ��aO�@gƝ��m�Gy�4W2�ҋ����%���pX@�k�DW�fEW��$j�>i��~��1���w�m}���}�����5I��x� ��H�*A8�� ��U�7~°���F�}4����DV�MZ��望C �'C��-�7�f�
데이터 복호화: 이는 openssl php 모듈을 사용하여 데이터 암호화 테스트입니다.

PHP OpenSSL 함수 매뉴얼