侯体宗的博客 RSA通过给出的公钥加密后返回来,api接口拿到加密json串后用私钥解密

石可破,丹可磨
  • 首页
  • laravel8仿版
  • beego仿版
  • go_聊天
  • 人生
  • 技术
  • php
  • 架构
  • 数据库
  • 更多
    • 文件下载
    • 匿名群聊
    • 群聊(进来吹会!)
    • 留言
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册
    • 设置栏目
    • 更多设置
    • 分割线

RSA通过给出的公钥加密后返回来,api接口拿到加密json串后用私钥解密

技术  /  管理员 发布于 2020-08-14 14:14:45   936

场景:互相给对方公钥,然后互相用公钥加密信息交互,互相用自己的私钥解密对方用对方加密的信息,有点拗口

同一个项目:上一篇写的是加密,这篇就写解密,想看加密的可以自行查阅

请求参数:

{






"biz_channel":"",






"timestamp":
"1587977248039",





"data":
"...此处是明文转json后RSA加密后的密文...",


}

这是对方post给我的数据其中data元素是对方用我的公钥加密的,我这边需要用我的私钥解密才能看到内容

私钥:

        $private_key = '-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBANwoAxkWcWcHPqCm
ij9+J+t1+hR1l4792zfk1n1MEyqXnGKmLzF6Go4mC3vWmh844TWWWEb1UVF7+nnc
SzryQN40M/XNkqQ7Wo9qG/7I4QfI/4QDmEMI+y+un2n3/50eBCTMDLdReMDtjYI4
Y3dxTk9T8RZXhV5XcUtlE4fwsCxVAgMBAAECgYBBXHu2+gvG+8ajKW6H9Sti447Q
fiz13fY0fPMVFf3mukZKn24JcWfq5e6o4Ii3Vkq+fxlMT87Js1Yk0btgD8Yj5QzJ
ED0HcqK6EdbxKIcApOX8seUUc6J4sX63q2Cob5feXNejpHl5OUVNpNBdl79FGqdA
7dRF2/R+T1sR3meQYQJBAPq8lP1JEP7rWGkvYmpgVlhUmzBG5GdDjenA5l2dTuch
aIQfRyafeeqJxm3GPrv3ti5bq05QO4jntQaYodCYua0CQQDgxxilXgnrKPWNWeGs
2hFe5aYN23aYQh7XjArfBVorxuiVyrkYqffPBgLJSP8u+oNH0GTuD8Kp+2gwcB7G
K2JJAkEAnRY29bSoLD2AB25DZ0fx8KcZDxbrE/MT3uYWrYHXpCCfHV+HMSBqvlEQ
+0dfmF3qSoLuAUNs+SnJlVdc0ZZNhQJAcZEmSqbwq/fN2NUIyKSFEkVFWMsBaHw/
yPfgpj22CVg+OzBpxKRbqCWJUtmm1L2NhsMru3wLBocXZSHA6q8QwQJBALL6ON3e
Pw44RBPMvB9ut98SOQZD+SbvvNfDUuxDbng7FikZaQl7yJMvuTTaoUOTLMdYFej5
JdvsyKo3aThLdEU=
-----END PRIVATE KEY-----';

解密方式 

默认就是方式1,还有一种就是加密长度超出了就解不出来的就需要分段分割解密 方式2


参数描述:

参数$query接口接到的参数,就是请求参数

参数$encrypted就是加密json串

参数$decrypted就是解密信息了

解密1: 

默认解密

$pi_key =  openssl_pkey_get_private($private_key);//这个函数可用来判断私钥是否是可用的,可用返回资源id Resource id

$encrypted = $query['data'];

$decrypted = "";

openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);//私钥解密

echo $decrypted,"\n";


解密2:

分割解密

$decrypted = '';

foreach (str_split($this->urlsafe_b64decode($query['data']), 128) as $chunk) {

openssl_private_decrypt($chunk, $decryptData, $private_key);

$decrypted .= $decryptData;

}


//解密码时把转换后的符号替换特殊符号

function urlsafe_b64decode($string) {

     $data = str_replace(array('-','_'),array('+','/'),$string);

     $mod4 = strlen($data) % 4;

     if ($mod4) {

         $data .= substr('====', $mod4);

     }

     return base64_decode($data);

}


拿到解密的信息你就可以该干嘛干嘛

昵称:

邮箱:

0条评论
最新最热
  • 分类目录
  • 人生 (119)
  • 技术 (46)
  • linux (23)
  • blog从零开始 (9)
  • php (48)
  • 架构 (14)
  • 前端 (22)
  • TP(3/5) (14)
  • 数据库 (29)
  • 微信 (2)
  • Laravel (56)
  • Redis (3)
  • Docker (2)
  • Go (8)
  • 近期文章
  • PHP程序员2021年最新面试题集-持续更新中...(0个评论)
  • PHP数组的底层实现原理浅析(0个评论)
  • php7垃圾回收变量的GC机制详解(0个评论)
  • 在Laravel中进行类型转换详解(0个评论)
  • mysql数据库中事务的四个特征及四种隔离级别的浅析描述(0个评论)
  • Linux awk 命令及统计nginx日志里访问次数最多的前十个IP(0个评论)
  • 论不要在mysql中使用[utf8]编码,如果要用请用[utf8mb4](0个评论)
  • JWT源码实现逻辑详解(0个评论)
  • Laravel内核分析-设计模式之观察者模式(0个评论)
  • Laravel内核分析-设计模式之装饰模式(0个评论)
  • 近期评论
  • 博主 在

    国内用什么翻墙使用谷歌?上外网神器Ghelper插件详解中评论 @请教  小图标没有出现 重复检查步骤5,进去看看右下角是否开启..
  • 请教 在

    国内用什么翻墙使用谷歌?上外网神器Ghelper插件详解中评论 你好,我也遇到了安装完右上角没有显示图标,也不能打开相关网页的问题,用的是谷歌浏..
  • Test11 在

    laravel查询构造器中whereNotKey,whereKey,firstWhere用法详解中评论 <script>alert(\test\)</script&g..
  • 博主 在

    国内用什么翻墙使用谷歌?上外网神器Ghelper插件详解中评论 @西瓜: 每一步都操作完达到效果了吗? 对了是用谷歌浏览器吧..
  • 西瓜 在

    国内用什么翻墙使用谷歌?上外网神器Ghelper插件详解中评论 你好 我安装完右上角没有显示图标,也不能打开相关网页,是怎么回事呢?..
  • 文章归档
  • 2016-10 (34)
  • 2016-11 (21)
  • 2017-06 (5)
  • 2017-07 (11)
  • 2017-08 (6)
  • 2017-09 (7)
  • 2017-10 (11)
  • 2017-11 (4)
  • 2017-12 (3)
  • 2018-01 (9)
  • 2018-02 (2)
  • 2018-03 (2)
  • 2018-04 (1)
  • 2018-05 (3)
  • 2018-06 (1)
  • 2018-10 (1)
  • 2018-11 (1)
  • 2020-03 (5)
  • 2020-04 (85)
  • 2020-05 (42)
  • 2020-06 (35)
  • 2020-07 (22)
  • 2020-08 (11)
  • 2020-09 (14)
  • 2020-10 (7)
  • 2020-11 (8)
  • 2020-12 (6)
  • 2021-01 (6)
  • 2021-02 (6)
  • 2021-03 (2)
Top
  • 友情链接
  • 侯体宗的博客
  • 三防加固笔记本
  • 澜溪博客
  • 心中hope
  • 徒步认知的博客
  • 陈大剩博客
  • 赵波的博客
  • 佘春晓的博客
  • 自动友链系统

Auther ·HouTiZong© 2009-2020 zongscan.com 版权所有ICP证: 粤ICP备20027696号 PHP交流群 也可以扫右边的二维码

侯体宗的博客