PHP中使用OpenSSL產生認證及加密解密詳解

來源:互聯網
上載者:User
這篇文章主要介紹了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);}

以上就是本文的全部內容,希望對大家的學習有所協助。


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.