php/js/linux: js加密(rsa公钥加密) php解密(rsa私钥解密)
2023-09-14 08:57:51 时间
php/js/linux: js加密(rsa公钥加密) php解密(rsa私钥解密)
一:
js rsa 插件
https://github.com/UFO0001/WX_RSA
或者:
https://files.cnblogs.com/files/achengmu/WX_RSA-master.zip
二:
代码所在的服务器生成:private_key/public_key 两个文件
php代码如下:
<?php /** * Created by PhpStorm. * User: Administrator * Date: 2017/11/10 * Time: 15:29 */ class RsaLogic { private $public_key = ''; //公密钥 private $private_key = ''; //私密钥 private $public_key_resource = ''; //公密钥资源 private $private_key_resource = ''; //私密钥资源 /** * 架构函数 * @param [string] $public_key_file [公密钥文件地址] * @param [string] $private_key_file [私密钥文件地址] */ public function __construct($public_key_file,$private_key_file) { try { if(!file_exists($public_key_file) || !file_exists($private_key_file)) { throw new Exception('key file no exists'); } if (false == ($this->public_key = file_get_contents($public_key_file)) || false == ($this->private_key = file_get_contents($private_key_file))) { throw new Exception('read key file fail'); } if(false == ($this->public_key_resource = $this->is_bad_public_key($this->public_key)) || false == ($this->private_key_resource = $this->is_bad_private_key($this->private_key))) { throw new Exception('public key or private key no usable'); } } catch (Exception $e) { die($e->getMessage()); } } private function is_bad_public_key($public_key) { return openssl_pkey_get_public($public_key); } private function is_bad_private_key($private_key) { return openssl_pkey_get_private($private_key); } /** * 生成一对公私密钥 成功返回 公私密钥数组 失败 返回 false */ public function create_key() { $res = openssl_pkey_new(); if($res == false) return false; openssl_pkey_export($res, $private_key); $public_key = openssl_pkey_get_details($res); return array('public_key'=>$public_key["key"],'private_key'=>$private_key); } /** * 用私密钥加密 */ public function private_encrypt($input) { openssl_private_encrypt($input,$output,$this->private_key_resource); return base64_encode($output); } /** * 解密 私密钥加密后的密文 */ public function public_decrypt($input) { openssl_public_decrypt(base64_decode($input),$output,$this->public_key_resource); return $output; } /** * 用公密钥加密 */ public function public_encrypt($input) { openssl_public_encrypt($input,$output,$this->public_key_resource); return base64_encode($output); } /** * 解密 公密钥加密后的密文 */ public function private_decrypt($input) { openssl_private_decrypt(base64_decode($input),$output,$this->private_key_resource); return $output; } }
示例:
$all = $this->getPost('all'); $public_key = dirname(__DIR__).'/logic/public_key.txt'; $private_key = dirname(__DIR__).'/logic/private_key.txt'; $rsa = new RsaLogic($public_key, $private_key); $all = $rsa->private_decrypt($all); echo $all;exit;
相关文章
- linux使用tar命令打包压缩时排除某个文件夹或文件
- JS框架_(JQuery.js)夜晚天空满天星星闪烁动画
- linux部署的flask项目配置static
- 【学习总结】快速上手Linux玩转典型应用-第6章-linux常用命令讲解
- Linux进程管理
- php:在linux上用sudo提升权限(centos 8 / PHP 7.4.2)
- Docker 基础技术之 Linux namespace 源码分析
- Spark修炼之道(基础篇)——Linux大数据开发基础:第十一节:Shell编程入门(三)
- [Linux] Use find to search for filename patterns
- Linux安装gcc
- Linux下Postfix的配置和使用
- 011-linux压缩和解压文件命令
- L86.linux命令每日一练 -- 第12章 Linux系统常用内置命令(二)
- L71.linux命令每日一练 -- 第十章 Linux网络管理命令 -- wget和mailq
- L67.linux命令每日一练 -- 第十章 Linux网络管理命令 -- netstat和ss
- L64.linux命令每日一练 -- 第十章 Linux网络管理命令 -- ifconfig和ifup
- L55.linux命令每日一练 -- 第八章 Linux磁盘与文件系统管理命令 -- mkswap和swapon
- L36.linux命令每日一练 -- 第五章 Linux信息显示与搜索文件命令 -- locate和updatedb
- L2.linux命令每日一练 -- 第一章 Linux命令行简介
- 嵌入式linux开发,Linux下访问PHY芯片寄存器,获取phyID号,获取phy的link状态
- linux下安装node.js
- 使用 Linux Centos Docker 安装 2Bizbix
- 一文详解 Linux 系统常用监控工具(top,htop,iotop,iftop)
- 【JS高级】js之闭包对象_04
- Linux 命令总结
- 嵌入式linux开发,ppp移植,pppd守护进程移植