青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

S.l.e!ep.¢%

像打了激速一樣,以四倍的速度運轉,開心的工作
簡單、開放、平等的公司文化;尊重個性、自由與個人價值;
posts - 1098, comments - 335, trackbacks - 0, articles - 1
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

PHP中使用OpenSSL來產生證書加密解密源代碼- -

??????????????????????????????????????

我想這段代碼足夠簡單,沒必要寫函數說明了吧。

該程序在linux+Apache 2.0 + PHP Version 4.2.2 中運行通過。

大致功能有:1。產生證書;2。使用RSA算法加密解密任意長度數據。

--------------------------------------------------

/*
?* Class COPenSSLCrypt
?* Author? : pigo chu<pigo@ms5.url.com.tw>
?* Date??? : 2004-11-12
?* Version : 0.01
?* Revision History:
?*?Lihui Lei 2005-05-18
*/

class COpenSSLCrypt {

??? /* All member variable is private */
??? var $publicKey? = "";
??? var $privateKey = "";
??? var $resourcePubKey = NULL;
??? var $resourcePriKey = NULL;
??? var $lastError = "";
??? var $debugMode = false;
??? var $keyLength = 64;
??? var $config = NULL;

??? /*
???? * Construct Method
???? * if $dn is not null , then this class will Generate CSR with $dn
???? * NOTE $dn is an array like this :
???? *???? array(
???? *???????? "countryName" => "UK",
???? *???????? "stateOrProvinceName" => "Somerset",
???? *???????? "localityName" => "Glastonbury",
???? *???????? "organizationName" => "The Brain Room Limited",
???? *???????? "organizationalUnitName" => "PHP Documentation Team",
???? *???????? "commonName" => "Wez Furlong",
???? *???????? "emailAddress" => "wez@example.com"
???? *???????? );
???? */
??? function COpenSSLCrypt( $dn=NULL , $passphrase=NULL )
??? {
??????? if(is_array( $dn ))
??????? {
??????????? $this->GenerateKey($dn , $passphrase);
??????? }
??? }

??? /*
???? * Generate CSR and create all key , if $dn is NULL then use default dn to generate
???? */
??? function GenerateKey($dn=NULL , $config= NULL , $passphrase=NULL )
??? {
??????? if(!$dn)
??????? {
??????????? $dn = array(
??????????????? "countryName" => "CN",
??????????????? "stateOrProvinceName" => "BEIJING",
??????????????? "localityName" => "BeiJing",
??????????????? "organizationName" => "IVT Corporation",
??????????????? "organizationalUnitName" => "BlueSoleil Group",
??????????????? "commonName" => "??????????????? "emailAddress" => "support@bluesoleil.com"
??????????? );
??????? }
??????? $privkey = openssl_pkey_new();
???????
???? if (!$config)
???? {
???? ?$config = array(
??? ?"digest_alg" => "sha1",
??? ?"private_key_bits" => $keyLength,
??? ?"private_key_type" => OPENSSL_KEYTYPE_RSA,
??? ?"encrypt_key" => false
??? ?);
??}

??????? $csr = openssl_csr_new($dn, $privkey);
??????? $sscert = openssl_csr_sign($csr, null, $privkey, 365);
??????? echo "
CSR:
";
??????? openssl_csr_export($csr, $csrout);
??????? echo "
Certificate: public key
";
??????? openssl_x509_export($sscert, $certout);
??????? echo "
private key:
";
??????? if($passphrase != NULL){
??????????? openssl_pkey_export($privkey, $pkeyout, $passphrase);
??????? }else{
??????????? openssl_pkey_export($privkey, $pkeyout);
??????? }
??????? $this->setPublicKey($certout);
??????? $this->setPrivateKey($pkeyout);
??? }

?? /*
???? * Generate CSR and create all key , if $dn is NULL then use default dn to generate
???? */
??? function GenerateKeyToFile($csrFile=NULL, $certFile=NULL, $privkeyFile=NULL )
??? {

??? ?if (!csrFile or !certFile or !privkeyFile)
??? ?{
??? ??echo "

Please set key files' name and path.


";
??? ??return false;
??? ?}
??????? if(!$dn)
??????? {
??????????? $dn = array(
??????????????? "countryName" => "CN",
??????????????? "stateOrProvinceName" => "BEIJING",
??????????????? "localityName" => "BeiJing",
??????????????? "organizationName" => "IVT Corporation",
??????????????? "organizationalUnitName" => "BlueSoleil Group",
??????????????? "commonName" => "??????????????? "emailAddress" => "support@bluesoleil.com"
??????????? );
??????? }
???????
??????? $privkey = openssl_pkey_new();
??????? $csr = openssl_csr_new($dn, $privkey);
??????? $sscert = openssl_csr_sign($csr, null, $privkey, 365);
??????? openssl_csr_export_to_file($csr, $csrFile);//and debug_zval_dump($csrout);;
??????? openssl_x509_export_to_file($sscert, $certFile);???
??????? if($passphrase != NULL){
??????????? openssl_pkey_export_to_file($privkey, $privkeyFile, $passphrase);
??????? }else{
??????????? openssl_pkey_export_to_file($privkey, $privkeyFile);
??????? }

??????? return true;
??? }


??? function setPublicKey( $key )
??? {
??? ?$this->publicKey = $key;
??? ?if( !($this->resourcePubKey = @openssl_get_publickey($key)) )
??? ?{
??????????? $this->setDebug();
??????????? return false;
??? ?}
??? ?return true;
??? }


??? function setPrivateKey( $key , $passphrase="" )
??? {
??? ?$this->privateKey = $key;
??? ?if( !($this->resourcePriKey = @openssl_get_privatekey($key , $passphrase)) )
??? ?{
??????????? $this->setDebug();
??????????? return false;
??? ?}
??? ?return true;
??? }

??? function getPublicKey()
??? {
??????? return $this->publicKey;
??? }

??? function getPrivateKey()
??? {
??????? return $this->privateKey;
??? }

??? function encrypt( $source )
??? {
??????? if(!$this->resourcePubKey)
??????? {
??????????? $this->setDebug("decrypt(string) error : No Public Key Resource.\n");
??????????? return false;
??????? }
??? ?$ret = "";
??????? $len = strlen($source);
??????? echo "The encrypted source length is ". $len;
??????? /*
???????? * Why encrypt each 64 bytes ?
???????? * Because openssl_public_enrypt() can't encrypt large data
???????? * Anyone know why ?
???????? */
??????? for($i=0;$i<$len;$i+=64)
??????? {
??????????? if(!openssl_public_encrypt(substr($source,$i,64),$new_out,$this->resourcePubKey))
??????????? {
??????????? ?$errorText = "encrypt(string) error : " . openssl_error_string() . "\n";
??????????? ?$errorText.= "Data Dump : \n" . strtoupper(bin2hex($source)) ."\n";
??????????????? $this->setDebug( $errorText );
??????????????? return false;
??????????? }
??????????? $ret .= $new_out;
??????? }?
??????? return $ret;
??? }

?function publicEncrypt_keyFromFile($data, $publicKeyFile, $passphrase=NULL)
?{
??$fp=fopen($publicKeyFile, "r");
??$public_key=fread($fp,8192);
??fclose($fp);
??// $passphrase is required if your key is encoded (suggested)
??if($passphrase != NULL)
???$res = openssl_get_publickey($public_key);
??else
???$res = openssl_get_publickey($public_key);
??openssl_public_encrypt($data, $encrypted, $res);?
??return $encrypted;
?}

?function privateDecrypt_keyFromFile($data, $privateKeyFile, $passphrase=NULL)
?{
??$fp=fopen ($privateKeyFile,"r");
??$private_key=fread($fp,8192);
??fclose($fp);
??if($passphrase != NULL)
???openssl_get_privatekey($private_key, $passphrase);
??else
???openssl_get_privatekey($private_key);
???
??openssl_private_decrypt($data, $decrpted, $private_key);??
??return $decrpted;
?}
?
??? function decrypt( $cryptedData )
??? {
??????? if(!$this->resourcePriKey)
??????? {
??????????? $this->setDebug("decrypt(string) error : No Private Key Resource.\n");
??????????? return false;
??????? }
??? ?$ret = "";
??????? $len = strlen($cryptedData);
??????? /*
???????? * Why decrypt each 128 bytes?
???????? * Because openssl_private_decrypt can't decrypt large data.
???????? * And when use openssl_public_enrypt to crypt data . It will create a 128 bytes string(Encoded)
???????? */
??????? for($i=0;$i<$len;$i+=128)
??????? {
??????????? if(!openssl_private_decrypt(substr($cryptedData,$i,128),$new_out,$this->resourcePriKey))
??????????? {
??????????? ?$errorText = "decrypt(string) error : " . openssl_error_string() . "\n";
??????????? ?$errorText.= "Data Dump : \n" . strtoupper(bin2hex($cryptedData)) ."\n";
??????????????? $this->setDebug( $errorText );
??????????????? return false;
??????????? }
??????????? $ret .= $new_out;
??????? }?
??????? return $ret;
??? }
???
??? function setKeyLength( $bitNum=64 )
??? {
??? ?$keyLength = $bitNum;
??? }
???
??? function getLastError()
??? {
??????? return $this->lastError;
??? }

??? function setDebugMode( $bl=false )
??? {
??????? $this->debugMode = $bl;
??? }

??? function setDebug( $msg="" )
??? {
??????? if(!$msg)
??????????? $this->lastError = openssl_error_string();
??????? else
??????????? $this->lastError = $msg;
??????? if( $this->debugMode )
??????????? echo $this->lastError;
??? }???
}


//echo phpinfo();
echo "

Openssl Encrypt/Decrypt Example:


";

// use a large data for test
$testStr= <<
This a php script, you cannot see it.
EOT;

// Now I am server
$server_ssl = new COpenSSLCrypt;
$server_ssl->setDebugMode(true);

//Generate Key File.
$ret = $server_ssl->GenerateKeyToFile("/home/test/cert.csr",
????"/home/test/cert.pem",
????"/home/test/privkey.pem");
if (!$ret)
?echo "
Error to generate key.";
?
echo "

The plain text is:

".$testStr;?

// Start Encrpt process at the server end.
echo "

The encrpyted result is:

";
$cryptedData = $server_ssl->publicEncrypt_keyFromFile($testStr, "/home/test/cert.pem");
echo $cryptedData;

// Start Decrpt process at the client end.
echo "

The decrpyted result is:

";
$decryptedData = $server_ssl->privateDecrypt_keyFromFile($cryptedData, "/home/test/privkey.pem");
echo $decryptedData;

/*// Now I ma client

$client_ssl = new COpenSSLCrypt;
$client_ssl->setDebugMode(true);
$client_ssl->GenerateKeyToFile("/home/test/cert.csr",
????"/home/test/cert.pem",
????"/home/test/privkey.pem");


// Now I am server , and client send a public key to me
$client_public_key = $client_ssl->getPublicKey();
$server_ssl->setPublicKey( $client_public_key );
$cryptedText = $server_ssl->encrypt($testStr);

// Now I am client , and I will decrypt $cryptedText
echo "The encrypted length is ". strlen($cryptedText) . "
";
$dumpData = strtoupper(bin2hex($cryptedText));
echo "Dump CryptedText :".? $dumpData. "
";
echo "The encrypted length is ". strlen($dumpData) . "
";
echo "Decrypt Text : ". $client_ssl->decrypt( $cryptedText ) . "
"

// Now I am server
$server_ssl = new COpenSSLCrypt;
$server_ssl->setDebugMode(true);


// Now I ma client
$client_ssl = new COpenSSLCrypt;
$client_ssl->setDebugMode(true);
$client_ssl->GenerateKeyToFile("/home/test/cert.pem",
???????"/home/test/cert.pem",
???????"/home/test/privkey.pem");


// Now I am server , and client send a public key to me
$client_public_key = $client_ssl->getPublicKey();
$server_ssl->setPublicKey( $client_public_key );
$cryptedText = $server_ssl->encrypt($testStr);

// Now I am client , and I will decrypt $cryptedText
echo "The encrypted length is ". strlen($cryptedText) . "
";
$dumpData = strtoupper(bin2hex($cryptedText));
echo "Dump CryptedText :".? $dumpData. "
";
echo "The encrypted length is ". strlen($dumpData) . "
";
echo "Decrypt Text : ". $client_ssl->decrypt( $cryptedText ) . "
"
*/
?>

- 作者: Goooder 2005年05月31日, 星期二 14:47 加入博采

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            影音先锋久久久| 亚洲一区久久久| 久久久一二三| 久久久av毛片精品| 久久久人成影片一区二区三区| 亚洲一级网站| 欧美一区二粉嫩精品国产一线天| 午夜一区二区三视频在线观看| 性久久久久久久久久久久| 久久超碰97人人做人人爱| 老司机精品视频网站| 欧美成人首页| 国产精品久久久久久福利一牛影视 | 亚洲国产精品一区在线观看不卡 | 噜噜噜噜噜久久久久久91| 99国内精品久久| 欧美色另类天堂2015| 国产精品美女久久久久av超清| 国产精品日日做人人爱| 一区二区亚洲精品国产| 亚洲视频你懂的| 久久综合久久综合这里只有精品| 欧美好骚综合网| 亚洲自拍偷拍色片视频| 欧美a级一区二区| 国产精品亚洲人在线观看| 亚洲国产成人午夜在线一区 | 99av国产精品欲麻豆| 欧美一区日本一区韩国一区| 欧美成人首页| 午夜精品久久久久| 欧美另类变人与禽xxxxx| 国产又爽又黄的激情精品视频| 夜夜嗨av一区二区三区网页| 久久久免费观看视频| 夜夜嗨一区二区三区| 久久亚洲综合色| 国产日产欧美一区| 亚洲婷婷综合色高清在线| 欧美凹凸一区二区三区视频| 亚洲欧美日本日韩| 国产精品v欧美精品v日本精品动漫| 亚洲国产一区视频| 免费在线播放第一区高清av| 亚洲欧美日韩精品久久久久| 欧美日韩中字| 中文精品一区二区三区| 亚洲精美视频| 午夜视频一区在线观看| 国产精品日韩一区二区| 亚洲午夜在线观看视频在线| 91久久久久久久久| 欧美福利视频在线| 亚洲精品韩国| 亚洲国产视频一区二区| 欧美成人免费小视频| 中文av字幕一区| 亚洲永久免费av| 国产精品一区一区三区| 欧美α欧美αv大片| 久久综合婷婷| 国产噜噜噜噜噜久久久久久久久| 久久久久国产精品www| 日韩视频一区二区三区在线播放免费观看 | 亚洲欧美日韩一区| 欧美精品在线看| 欧美不卡视频一区发布| 免费观看成人| 亚洲人成在线播放网站岛国| 亚洲福利视频专区| 欧美激情一区二区| 中日韩男男gay无套| 一本色道久久综合狠狠躁篇怎么玩 | 欧美在线观看网址综合| 国产亚洲欧美激情| 免费欧美视频| 欧美伦理91i| 亚洲综合电影一区二区三区| 亚洲影视九九影院在线观看| 国产一区二区欧美日韩| 欧美福利小视频| 国产精品v欧美精品v日本精品动漫| 欧美一区二区三区在线播放| 久久精品视频免费播放| 亚洲日本精品国产第一区| 日韩亚洲一区在线播放| 国产一区二区三区久久精品| 亚洲二区在线| 国产麻豆综合| 欧美激情bt| 国产精品日韩欧美一区| 欧美二区在线播放| 国产精品一区二区三区四区五区 | 亚洲高清网站| 国产精品一区视频| 亚洲人成啪啪网站| 国产一区二区三区免费在线观看| 亚洲福利在线观看| 国产香蕉久久精品综合网| 亚洲韩国青草视频| 国产亚洲精品久久久久动| 亚洲国产欧美日韩精品| 国产视频精品网| 日韩视频一区二区在线观看 | 亚洲欧美日韩国产一区| 亚洲精品国久久99热| 欧美亚洲视频在线观看| 一区二区三区精品国产| 另类图片国产| 久久久999精品免费| 欧美日韩喷水| 亚洲国产成人午夜在线一区| 久久久久免费视频| 国产精品免费看片| 亚洲国产高清一区二区三区| 国产午夜精品理论片a级探花| 亚洲精品黄色| 亚洲国产福利在线| 性欧美长视频| 欧美一区1区三区3区公司| 欧美日韩国产成人在线| 欧美高清视频一区二区| 狠狠色丁香久久综合频道| 亚洲欧美文学| 欧美一级免费视频| 国产精品美女www爽爽爽视频| 亚洲精选一区| 一区二区激情小说| 欧美日本精品在线| 亚洲精品影视在线观看| 99精品99| 国产精品白丝黑袜喷水久久久| 91久久精品国产91性色tv| 亚洲片在线观看| 欧美国产第一页| 亚洲精品综合精品自拍| 日韩视频永久免费| 欧美电影在线| 亚洲伦伦在线| 亚洲综合首页| 国产精品一区二区久久精品| 亚洲免费在线精品一区| 欧美专区亚洲专区| 禁久久精品乱码| 免费成人av在线| 亚洲欧洲一区二区天堂久久| 一本色道久久88综合亚洲精品ⅰ | 久久人人精品| 红杏aⅴ成人免费视频| 久久久久9999亚洲精品| 欧美国产日本| 一区二区精品| 国产日韩欧美精品一区| 久久久久久久久蜜桃| 亚洲第一网站免费视频| 一本色道久久88精品综合| 国产精品日韩精品欧美精品| 欧美在线亚洲一区| 91久久精品一区二区别| 亚洲一区二区欧美日韩| 国产亚洲欧美色| 欧美成va人片在线观看| 一区二区三区四区五区精品视频| 午夜免费久久久久| 亚洲成色精品| 国产精品成人v| 久久久久久网| 亚洲久久一区| 久久米奇亚洲| 一区二区三区国产精华| 国产在线不卡视频| 欧美男人的天堂| 欧美主播一区二区三区美女 久久精品人 | 亚洲一区二区在线免费观看视频| 久久久777| 亚洲一区免费看| 在线电影国产精品| 久久精品国产精品亚洲综合| 夜夜爽夜夜爽精品视频| 国产日韩欧美在线看| 欧美国产日韩一二三区| 亚洲欧美日韩成人高清在线一区| 欧美大色视频| 久久精品卡一| 亚洲桃色在线一区| 最新亚洲一区| 狠狠入ady亚洲精品经典电影| 欧美日韩中国免费专区在线看| 久久视频国产精品免费视频在线| 一本一本久久a久久精品综合麻豆| 开元免费观看欧美电视剧网站| 亚洲午夜一区| 亚洲精品一区二区三| 影音先锋日韩有码| 国产日韩在线看| 国产精品国产自产拍高清av| 欧美激情亚洲激情| 另类综合日韩欧美亚洲| 久久久亚洲欧洲日产国码αv | 午夜精品福利一区二区三区av |