当前位置:Gxlcms > PHP教程 > php使用OpenSSL生成证书及加密解密示例代码

php使用OpenSSL生成证书及加密解密示例代码

时间:2021-07-01 10:21:17 帮助过:11人阅读

OpenSSL 是一个安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。

OpenSSL被曝出现严重安全漏洞后,发现多数通过SSL协议加密的网站使用名为OpenSSL的开源软件包。OpenSSL漏洞不仅影响以https开头的网站,黑客还可利用此漏洞直接对个人电脑发起“心脏出血”(Heartbleed)攻击。据分析,Windows上有大量软件使用了存在漏洞的OpenSSL代码库,可能被黑客攻击抓取用户电脑上的内存数据。

这篇文章主要介绍了PHP中使用OpenSSL生成证书及加密解密,需要的朋友可以参考下

依赖于OpenSSL扩展

  1. /*加密解密*/
  2. function authcode($string, $operation = 'E') {
  3. $ssl_public = file_get_contents(DATA_PATH."/conf/cert_public.key");
  4. $ssl_private = file_get_contents(DATA_PATH."/conf/cert_private.pem");
  5. $pi_key = openssl_pkey_get_private($ssl_private);//这个函数可用来判断私钥是否是可用的,可用返回资源id Resource id
  6. $pu_key = openssl_pkey_get_public($ssl_public);//这个函数可用来判断公钥是否是可用的
  7. if(false == ($pi_key || $pu_key)) return '证书错误';
  8. $data = "";
  9. if($operation=='D'){
  10. openssl_private_decrypt(base64_decode($string),$data,$pi_key);//私钥解密
  11. }else{
  12. openssl_public_encrypt($string,$data,$pu_key);//公钥加密
  13. $data = base64_encode($data);
  14. }
  15. return $data;
  16. }
  17. /*生成证书*/
  18. function exportOpenSSLFile(){
  19. $config = array(
  20. "digest_alg" => "sha512",
  21. "private_key_bits" => 4096, //字节数 512 1024 2048 4096 等
  22. "private_key_type" => OPENSSL_KEYTYPE_RSA, //加密类型
  23. );
  24. $res = openssl_pkey_new($config);
  25. if($res == false) return false;
  26. openssl_pkey_export($res, $private_key);
  27. $public_key = openssl_pkey_get_details($res);
  28. $public_key = $public_key["key"];
  29. file_put_contents(DATA_PATH."/conf/cert_public.key",$public_key);
  30. file_put_contents(DATA_PATH."/conf/cert_private.pem",$private_key);
  31. openssl_free_key($res);
  32. }

以上就是php 使用OpenSSL生成证书及加密解密示例代码的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行