最近在着手写一个服务端安全接口规范,需要用到RSA加密解密。所以小试牛刀一下,并且做个记录。
环境: Win7 64位
PHP 5.6.12
需要原型工具:
一、安装OpenSSL
随意安装到哪里
二、进入到OpenSLL的bin目录下进行私钥和公钥的生成
//生成私钥openssl genrsa -out rsa_private_key.pem 1024 //生成公钥openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
将生产的私钥、公钥拷贝到你的PHP项目中
三、开启PHP的OpenSSL扩展
将php.ini中的extension=php_openssl.dll开启(去掉;)
四、PHP加密解密练习
附录:
一、在Win下面使用生成私钥的时候遇到一个BUG:
错误:
WARNING: can't open config file: /usr/local/ssl/openssl.cnfLoading 'screen' into random state - doneGenerating RSA private key, 1024 bit long modulus.........++++++.........................................++++++unable to write 'random state'e is 65537 (0x10001)
解决办法:
在CMD中进行如下操作
set OPENSSL_CONF=c:OpenSSL-Win32binopenssl.cfg
或者
set OPENSSL_CONF=[path-to-OpenSSL-install-dir]binopenssl.cfg
PS:[path-to-OpenSSL-install-dir]为你的OpenSSL路径
二、参考资料: