首页 > 作文

php的RSA加密解密算法原理与用法分析

更新时间:2023-04-08 17:25:27 阅读: 评论:0

本文实例讲述了php的rsa加密解密算法原理与用法。分享给大家供大家参考,具体如下:

最近因为工作的需要,要倒腾支付宝支付相关的知识,因为支付宝应用了rsa加密机制,个人对此并不了解,所以在这里写下一篇总结。

1、生成公钥和私钥

要应用rsa算法,必须先生成公钥和私钥,公钥和私钥的生成可以借助openssl工具。

本次测验是在windows下进行的,可以到以下的地址下载windows安装包:,安装过程不再赘述。

安装过后,进入到安装目steal过去式录的bin目录下,执行如下命令:

openssl.exe     // 进入openssl程序genrsa -out rsa_private_key.pem 1024 //生成私钥,执行成功后可以在当前目录下看到生成了rsa_private_key.pem文件pkcs8 -topk8 -inform pem -in rsa_private_key.pem -outform pem -nocrypt  //如果你使用的java,需要将私钥转换成pkcs8格式rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem //生成公钥,执行成功后可以在当前目录下看到生成rsa_public_key.pem文件

公钥rsa_public_key.pem的内容:

—–begin public key—–
migfma0gcsqgsib3dqebaquaa4gnadcbiqkbgqdc5nsc6mhl9bmm6l8n7sq1+ft6
vf8lcu3jst8riy7wqxxd5xzomc0cjlxvz3vc0vgukkjyp6q2ozdocfgcp7q9infg
ngtnvlej1+nm0+snudbybnrfw8wwspg0jpq73cgmxodv+ighir6meitbdeh+z古体诗svc
grd0ovkyig+itgk3/qidaqab
—–end public key—–

私钥rsa_private_key.pem的内容:

—–begin rsa private key—–
miicxaibaakbgqdd4ka0yu7eg7za32oavdhlwxf9lyywxgn7ma9lffnfl57cpyoq
wf0oz8fe9/unjfoehs2xjdr奇门遁甲 周德东he+uqvtyx/9vi/znjgp9d7hpto2njhm/auykd+itl
cie2tu+sjjqi0jfvcpc3d0ootbhng35406cucraon/a52mxqngta4amsswidaqab
aogag25nwty39sruwt1vl9cyrbrsc15fp4sppg4o2imp4v2kr+g+749kqzpzhkmf
aabbrvevxzxaqr2zouvl8kx3u4hqy万通消糜栓4m/s1acoxnpijkb703xxa1yf2ta2cvlswtm
tsdwrw1wudf18yozf3q7aoymhpbumlmhh4mviywopfj0zaecqqd4a11q8sfpocik
fmz5jjymlmz9p8gxnbafwjxtdtxht/mupreaepslp3aeykbmjnygs04/loqzksp+
zg6j7/xzakeayi9zj8eaplleail8mb5wdwiibq/z92nmlsumh5foo013dvumbi8c
ccp1/go2sj3h4rqewycr360ytubnkkhosqjacrrpos3fokz8y329k3z6igy+rfmj
2tqlvvg5ybakbi0j5vunrpj6p+qbwfdlpviqp6nvzowffek0kuzfz/dj4wjbalyc
czcmuoarfepgc24zduzjtiqzo+g7d3yx7pokyrlzxhxjogekw8i0zxmca5pxyfip
c1vbginehedpfjy3wmkcqeh3fg0xdpufxetct5l1wht8lsn0ek3zmcfdepcbkuhw
ie5pbnn7ytpvt+jit3+fvezvszciw0ldnyd86ppos5g=
—–end rsa private key—–

公钥和私钥生成好了之后,私钥自己保存,将公钥交给第三方即可。

2、php的rsa加密解密

在做加密解密之手印墙前,首先要确保php已经开启了openssl拓展,可以通过phpinfo()函数进行查看。

通常情况下,有以下两种情形:

①通过公钥加密,通过私钥解密;

②通过私钥加密,通过公钥解密;

支付宝的业务场景属于第二种情形:

业务方支付宝发送支付请求,将sign参数通过自己的私钥加密过后发送到支付宝的接口;支付宝方向业务方发送支付结果,将sign参数通过自己的私钥加密过后发送到业务方的notify接口;

下面就以支付宝的业务逻辑为例,实现以下第二种加解密:

加密:

$data = "我是待加密的字符串";echo sign($data, 'rsa_private_key.pem'); /* 签名 */function sign($data, $rsaprivatekey) {   /* 获取私钥pem文件内容,$rsaprivatekey是指向私钥pem文件的路径 */   $prikey = file_get_contents($rsaprivatekey);   /* 从pem文件中提取私钥 */   $res = openssl_get_privatekey($prikey);   /* 对数据进行签名 */   //openssl_sign($data, $sign, $res);   openssl_private_encrypt($data, $sign, $res);   /* 释放资源 */   openssl_free_key($res);   /* 对签名进行ba64编码,变为可读的字符串 */   $sign = ba64_encode($sign);   return $sign; }

执行后得到如下字符串:

gentbwaboyt1l2tikaxgxnczdop8pynyntmnbyattmyyolxgjhm363ufehbnboihc3pzi7kvrwppkfsnuigns4matzacf0wojvc+26g5j19yqqb00fr+xvipevyn0sn9/uhlot6m6qj7h5adarevsy/30jtld6kdkkqf8k3eg+y=

解密:

$data = "gentbwaboyt1l2tikaxgxnczdop8pynyntmnbyattmyyolxgjhm363ufehbnboihc3pzi7kvrwppkfsnuigns4matzacf0wojvc+26g5j19yqqb00fr+xvipevyn0sn9/uhlot6m6qj7h5adarevsy/30jtld6kdkkqf8k3eg+y=";echo decrypt($data, 'rsa_public_key.pem');function decrypt($data, $rsapublickey) {   /* 获取公钥pem文件内容,$rsapublickey是指向公钥pem文件的路径 */   $pubkey = file_get_contents($rsapublickey);   /* 从pem文件中提取公钥 */   $res = openssl_get_publickey($pubkey);   /* 对数据进行解密 */   openssl_public_decrypt(ba64_decode($data), $decrypted, $res);   /* 释放资源 */   openssl_free_key($res);   return $decrypted; }

第一种情形与第二种情形类似,在此不在赘述。

注:支付宝使用的加密函数是openssl_sign,之后的校验可以使用openssl_verify函数进行校验。

ps:关于加密解密感兴趣的朋友还可以参考本站在线工具:

在线rsa加密/解密工具:

文字在线加密解密工具(包含aes、des、rc4等):

在线散列/哈希算法加密工具:

在线md5/hash/sha-1/sha-2/sha-256/sha-512/sha-3/ripemd-160加密工具:

在线sha1/sha224/sha256/sha384/sha512加密工具:

本文发布于:2023-04-08 17:25:25,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/d2a254fac1f49de5bfe3660b26127ba2.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:php的RSA加密解密算法原理与用法分析.doc

本文 PDF 下载地址:php的RSA加密解密算法原理与用法分析.pdf

标签:在线   公钥   支付宝   文件
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图