Home >Backend Development >PHP Tutorial >PHP simply implements SSL encryption, decryption, verification, and signature methods

PHP simply implements SSL encryption, decryption, verification, and signature methods

墨辰丷
墨辰丷Original
2018-06-05 16:12:121846browse

This article mainly introduces the simple implementation of SSL encryption, decryption, verification, and signature methods in PHP. Interested friends can refer to it. I hope it will be helpful to everyone.

Signature:

function sign($data) {
 //读取私钥文件
 $priKey = file_get_contents('key/rsa_private_key.pem');
 
 //转换为openssl密钥,必须是没有经过pkcs8转换的私钥
 $res = openssl_get_privatekey($priKey);
 
 //调用openssl内置签名方法,生成签名$sign
 openssl_sign($data, $sign, $res);
 
 //释放资源
 openssl_free_key($res);
 
 return $sign;
}

Verification:

function verify($data, $sign) {
 //读取支付宝公钥文件
 $pubKey = file_get_contents('key/alipay_public_key.pem');
 
 //转换为openssl格式密钥
 $res = openssl_get_publickey($pubKey);
 
 //调用openssl内置方法验签,返回bool值
 $result = (bool)openssl_verify($data, $sign, $res);
  
 //释放资源
 openssl_free_key($res);
 
 return $result;

Decryption

function decrypt($content) {
 
 //读取商户私钥
 $priKey = file_get_contents('key/rsa_private_key.pem');
  
 //转换为openssl密钥,必须是没有经过pkcs8转换的私钥
 $res = openssl_get_privatekey($priKey);
 
 //声明明文字符串变量
 $result = '';
 
 //循环按照128位解密
 for($i = 0; $i < strlen($content)/128; $i++ ) {
  $data = substr($content, $i * 128, 128);
   
 //拆分开长度为128的字符串片段通过私钥进行解密,返回$decrypt解析后的明文
  openssl_private_decrypt($data, $decrypt, $res);
 
 //明文片段拼接
  $result .= $decrypt;
 }
 
 //释放资源
 openssl_free_key($res);
 
 //返回明文
 return $result;
}

Summary: The above is the entire content of this article. I hope it will be helpful to everyone's study.

Related recommendations:

PHP implements exporting styled Excel instance sharing

PHP implements a method of forcing the specified callback type based on Callable

Sharing examples of two methods of converting PHP array encoding gbk and utf8 to each other

The above is the detailed content of PHP simply implements SSL encryption, decryption, verification, and signature methods. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn