欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

PHP中使用OpenSSL生成证书及加密解密

程序员文章站 2024-03-06 22:43:38
依赖于openssl扩展 /*加密解密*/ function authcode($string, $operation = 'e') { $ssl_pub...

依赖于openssl扩展

/*加密解密*/
function authcode($string, $operation = 'e') {
  $ssl_public = file_get_contents(data_path."/conf/cert_public.key");
  $ssl_private = file_get_contents(data_path."/conf/cert_private.pem");
  $pi_key = openssl_pkey_get_private($ssl_private);//这个函数可用来判断私钥是否是可用的,可用返回资源id resource id
  $pu_key = openssl_pkey_get_public($ssl_public);//这个函数可用来判断公钥是否是可用的
  if(false == ($pi_key || $pu_key)) return '证书错误';
  $data = "";
  if($operation=='d'){
    openssl_private_decrypt(base64_decode($string),$data,$pi_key);//私钥解密
  }else{
    openssl_public_encrypt($string,$data,$pu_key);//公钥加密
    $data = base64_encode($data);
  }
  return $data;
}
/*生成证书*/
function exportopensslfile(){
  $config = array(
    "digest_alg"    => "sha512",
    "private_key_bits" => 4096,           //字节数  512 1024 2048  4096 等
    "private_key_type" => openssl_keytype_rsa,   //加密类型
  );
  $res = openssl_pkey_new($config);
  if($res == false) return false;
  openssl_pkey_export($res, $private_key);
  $public_key = openssl_pkey_get_details($res);
  $public_key = $public_key["key"];
  file_put_contents(data_path."/conf/cert_public.key",$public_key);
  file_put_contents(data_path."/conf/cert_private.pem",$private_key);
  openssl_free_key($res);
}

更多关于openss的文章可以查看下面的相关文章