编程 使用PHP实现RSA算法生成数字的签名和验签

2024-11-17 05:02:38 +0800 CST views 2747

#关于如果生成公钥私钥的方法请看这篇文章 公钥私钥请看这里

<?php
$private_key = '-----BEGIN RSA PRIVATE KEY-----
MIICWwIBAAKBgQCEwLlhjT5UbnQ0czFnaVzQa59RAKzie+Y30jq/TGHDADPiRmqZ
yZd08O3S5sXh7BC3UaOYbIyA0xLdNCAyk53/ij3LyRa4pKrJihHJ7kNlSCUJuFei
TXdLE03InfJPTFSqaXodeAA08EOi8UuX2f0TiAZ/miM5xnhTxL2NsI8I5wIDAQAB
AoGAOEecUAcZTaImEbZkU3sPpix6NlUa9kmgqDmwPjmbmJgVZvCDcP9N/n3F1YuQ
iN8TlyQ9PvmF93eEn9Lhc4+xg2kQF9wnQp9gKQtmSZyd4Lw9NHvBy45Aj9iJSQQ/
jeMVZ+O0Yne//ErhL/X5DUOWGwcRKtw4qt7bf+u0VpcH+wECQQCIRllBIHqSEsSM
608o+mDdqmB//NloVaj0lpwG+cNnJ7iWWbv2d+qdTH0sIRsC+4WorZx0YfFJryi4
ZUYUF/sRAkEA+WI/MFO4TIFi3VAncyziRJxETNy+kzMxsyj4bLqb8KTrZs4P3oif
I71U4SrAr3c14xFekIfL6145WweLZQwUdwJAZ0+N0sXgpmT8BSlPNe27CdFknyL9
Xw+xqtuTJearsMR4N+OHj+6ROvcF3jKq27P7PEmB1ul5lzbnVAPTAOC9QQJAYPj/
MT+czsMROpXMgVDWu284b9r2kC68CLrJvx3hPXYjw1oleZcOqssYkmYZfyGP5rf+
WZ00glWlX+xTG/vSiQJAKVzxiohMqnUuNajLFXmUXgbYrCaL0prBV+qU9W7h8bd1
ymTh8N1UHKH+HzA5Hw8s/kt5vXDsTGB8SKlLuu8Wjg==
-----END RSA PRIVATE KEY-----';
 
$public_key = '-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCEwLlhjT5UbnQ0czFnaVzQa59R
AKzie+Y30jq/TGHDADPiRmqZyZd08O3S5sXh7BC3UaOYbIyA0xLdNCAyk53/ij3L
yRa4pKrJihHJ7kNlSCUJuFeiTXdLE03InfJPTFSqaXodeAA08EOi8UuX2f0TiAZ/
miM5xnhTxL2NsI8I5wIDAQAB
-----END PUBLIC KEY-----';
$pi_key =  openssl_pkey_get_private($private_key);
$pu_key = openssl_pkey_get_public($public_key);
$data = ["name"=>"芊诺网络","php"=>"7.1"];
$data = json_encode($data);
//公钥加密
echo "public key encrypt:\n";
openssl_public_encrypt($data,$encrypted,$pu_key);
$encrypted = base64_encode($encrypted);
echo $encrypted,"\n";
//私钥解密
echo "private key decrypt:\n";
openssl_private_decrypt(base64_decode($encrypted),$decrypted,$pi_key);
echo $decrypted,"\n";

//私钥签名
openssl_sign($data, $sign,$pi_key,OPENSSL_ALGO_SHA256);
$sign = base64_encode($sign);
echo "<br/>sign:".$sign;
//公钥验证
$res = openssl_verify($data, base64_decode($sign), $pu_key,OPENSSL_ALGO_SHA256);
echo "<br/>signverify:";
var_dump($res);

下篇文章我们介绍如何使用vue和后端进行加密交互。

复制全文 生成海报 php js go vue

推荐文章

Vue3如何执行响应式数据绑定?
2024-11-18 12:31:22 +0800 CST
Go语言SQL操作实战
2024-11-18 19:30:51 +0800 CST
介绍25个常用的正则表达式
2024-11-18 12:43:00 +0800 CST
JavaScript 策略模式
2024-11-19 07:34:29 +0800 CST
Requests库详细介绍
2024-11-18 05:53:37 +0800 CST
三种高效获取图标资源的平台
2024-11-18 18:18:19 +0800 CST
js一键生成随机颜色:randomColor
2024-11-18 10:13:44 +0800 CST
Go 接口:从入门到精通
2024-11-18 07:10:00 +0800 CST
介绍 Vue 3 中的新的 `emits` 选项
2024-11-17 04:45:50 +0800 CST
PHP 命令行模式后台执行指南
2025-05-14 10:05:31 +0800 CST
mysql关于在使用中的解决方法
2024-11-18 10:18:16 +0800 CST
Nginx 如何防止 DDoS 攻击
2024-11-18 21:51:48 +0800 CST
Python中何时应该使用异常处理
2024-11-19 01:16:28 +0800 CST
Vue3中的v-slot指令有什么改变?
2024-11-18 07:32:50 +0800 CST
用 Rust 构建一个 WebSocket 服务器
2024-11-19 10:08:22 +0800 CST
使用 Vue3 和 Axios 实现 CRUD 操作
2024-11-19 01:57:50 +0800 CST
使用xshell上传和下载文件
2024-11-18 12:55:11 +0800 CST
Vue3中如何处理路由和导航?
2024-11-18 16:56:14 +0800 CST
Vue中的样式绑定是如何实现的?
2024-11-18 10:52:14 +0800 CST
MySQL 主从同步一致性详解
2024-11-19 02:49:19 +0800 CST
2024年公司官方网站建设费用解析
2024-11-18 20:21:19 +0800 CST
程序员茄子在线接单