繁体   English   中英

加密/解密字符串(PHP)

[英]Crypt/decrypt string (PHP)

我需要加密和解密字符串。 我不能使用哈希,因为解密的字符串必须是可读的。 我知道mcrypt,但我正在寻找使用证书文件加密和解密的东西。

谢谢。

您可以通过openssl使用公钥/私钥,一旦使用一次或两次就非常简单

function encryptString($clearText)
{
  $keyFile=fopen("public.pem","r");
  $publicKey=fread($keyFile,8192);
  fclose($keyFile);

  openssl_get_publickey($publicKey);
  openssl_public_encrypt($clearText,$cryptText,$publicKey);
  return(base64_encode($cryptText));
}

function decryptString($cryptText)
{
  $keyFile=fopen("private.pem","r");
  $privateKey=fread($keyFile,8192);
  fclose($keyFile);

  openssl_get_privatekey($privateKey);
  $binText = base64_decode($cryptText);
  openssl_private_decrypt($binText,$clearText,$privateKey);
  return($clearText);
}

要生成一个密钥对,简要指南是http://en.wikibooks.org/wiki/Transwiki:Generate_a_keypair_using_OpenSSL

简而言之

openssl rsa -pubout -in private.pem -out public.pem

更新

@keepwalking在下面询问如何从命令行执行此操作,@ vstm以一个很棒的链接回复http://www.devco.net/archives/2006/02/13/public_-_private_key_encryption_using_openssl.php

要总结该页面,一旦创建了密钥,就可以使用以下命令加密文本文件file.txt并将其输出到file.ssl

openssl rsautl -encrypt -inkey public.pem -pubin -in file.txt -out file.ssl

要将file.ssl解密为另一个文件decrypt.txt ,您可以使用以下命令。

openssl rsautl -decrypt -inkey private.pem -in file.ssl -out decrypted.txt

好吧,如果你想使用非对称加密,你必须使用openssl_ * -functionsphpseclib,如果你的php上没有openssl。

另一件事是你不能使用像对称密钥这样的证书。 如果你有一个使用公钥加密的密文(证书包含公钥),那么你必须使用私钥解密,如果使用私钥加密密文,那么你必须使用公钥解密,否则它会赢得'工作。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM