ホームページ >バックエンド開発 >PHPチュートリアル >PHP での OpenSSL を使用した証明書の生成と暗号化と復号化の詳細な説明
この記事では主に、PHP での証明書の生成と暗号化と復号化のための OpenSSL の使用方法を紹介します。必要な友人は参照してください。
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); }
上記がこの内容の全体です。この記事から学んでいただければ幸いです。
関連する推奨事項:
PHP は、OpenSSL を使用して証明書と暗号化と復号化を生成する
PHP は DES を実装する暗号化と復号化カプセル化クラスの完全なメソッド
JS実装3 des+base64 暗号化と復号化アルゴリズム手順の詳細な説明
以上がPHP での OpenSSL を使用した証明書の生成と暗号化と復号化の詳細な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。