php 非对称加密解密类
<?php
namespace app\Parentclient\model;
header("Content-Type: text/html;charset=utf-8");
// 让敲代码成为一种 ___"时尚"
//
// .::::.
// .::::::::.
// :::::::::::
// ..:::::::::::'
// '::::::::::::'
// .::::::::::
// '::::::::::::::..
// ..::::::::::::.
// ``::::::::::::::::
// ::::``:::::::::' .:::.
// ::::' ':::::' .::::::::.
// .::::' :::: .:::::::'::::.
// .:::' ::::: .:::::::::' ':::::.
// .::' :::::.:::::::::' ':::::.
// .::' ::::::::::::::' ``::::.
// ...::: ::::::::::::' ``::.
// ```` ':. ':::::::::' ::::..
// '.:::::' '::'````..
// 美女保佑 ———— 项目无BUG_
$cookieStr = $this->rsa->private_encrypt($token); /*si秘钥加密*/
一般用撕钥加密,用公钥解密
/*
生成公钥、私钥对,私钥加密的内容能通过公钥解密(反过来亦可以)
下载开源RSA密钥生成工具openssl(通常Linux系统都自带该程序),解压缩至独立的文件夹,进入其中的bin目录,执行以下命令:
openssl genrsa -out rsa_private_key.pem 1024 #生成原始 RSA私钥文件 rsa_private_key.pem
openssl pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt -out private_key.pem #将原始 RSA私钥转换为 pkcs8格式
openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem #通过私钥生成对应 RSA公钥 rsa_public_key.pem
*/
$private_key = '-----BEGIN PRIVATE KEY-----
MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBAOH2AFAc8C9BzJTr
AaxUsOyUEIoT+T6u/T3YAhIYVcvVrM46GKSfcWu/iCI95c3RZIzyYZGYPnn2DsPD
Sus+pUr1eZVxZRgTDc0usYMyAr+/XPFcOEOt9T/kMJoTHl/6BbUweSDGFCovIQ7X
xuN0pLZITGUdyodxw7hS3A+AsqxhAgMBAAECgYBUU8RmIYaZfErnQJUNRUYJ5HAP
t8iK1i94RwbuzdonCgVFqXTM6xwfBAnADa2XlA+cclBrT4/xYBy+fkGVbXmtvk1j
kGWuVMXaI9jxQjwYrbiA5tT+kaWF4Gh5SyUnAKgLXX40YMCc5Fi/vXOD523QDvko
gnDMDODfs/ELaccuKQJBAPHhTXeJfYWYqCyHi1wO5ZFzUccJCL2OWYdbkkXx3fGC
gvLu6ybIuECz8sDxmd3ZpXUxo6n0mw2kA3TrfE6cf6cCQQDvJszYaddxwpx1yopB
dGBjXYGyOIf4CrZR9ryx3xfRIapNA7X6g5flMrltBo0yCqWtTmJKmmydQ3nzWOUk
nrS3AkA+8/W2k+lAeR/kHw8NUa88MPhqxhYpR8BTc2jZnX63WdF9KuO2/2y9Ilif
EQKL9BaVLus607f7T+G6b4O17hNnAkEA6teLKKkm64tT4Ue3ZHdHf8v+5Ggm/Shn
yS0mNvUAilkoxt/x/8LhkiyxcaKRXKaf8wOZ+fCS4Au24YRV4BQJGQJBALFDXGIT
mm23KFaIMC2Au/gpO5CBmwDkbdZaQXl6K6B/Vje6a3ke7mIiKCmkcG7kdax0LUta
1xJYypi0HZCq/0A=
-----END PRIVATE KEY-----';
$public_key = '-----BEGIN PUBLIC KEY-----
MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDh9gBQHPAvQcyU6wGsVLDslBCK
E/k+rv092AISGFXL1azOOhikn3Frv4giPeXN0WSM8mGRmD559g7Dw0rrPqVK9XmV
cWUYEw3NLrGDMgK/v1zxXDhDrfU/5DCaEx5f+gW1MHkgxhQqLyEO18bjdKS2SExl
HcqHccO4UtwPgLKsYQIDAQAB
-----END PUBLIC KEY-----';
file_put_contents('public_key.txt', $public_key);
file_put_contents('private_key.txt', $private_key);
/**
* rsa 非对称加解密
*/
class rsa {
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 private_encrypt($data){
$crypto = '';
foreach (str_split($data, 117) as $chunk) {
openssl_private_encrypt($chunk, $encryptData, $this->private_key_resource);
$crypto .= $encryptData;
}
$encrypted = $this->urlsafe_b64encode($crypto);//加密后的内容通常含有特殊字符,需要编码转换下,在网络间通过url传输时要注意base64编码是否是url安全的
return $encrypted;
}
//加密码时把特殊符号替换成URL可以带的内容
function urlsafe_b64encode($string) {
$data = base64_encode($string);
$data = str_replace(array('+','/','='),array('-','_',''),$data);
return $data;
}
//解密码时把转换后的符号替换特殊符号
function urlsafe_b64decode($string) {
$data = str_replace(array('-','_'),array('+','/'),$string);
$mod4 = strlen($data) % 4;
if ($mod4) {
$data .= substr('====', $mod4);
}
return base64_decode($data);
}
//私钥加密的内容通过公钥可用解密出来
public function public_decrypt($encrypted){
$crypto = '';
foreach (str_split($this->urlsafe_b64decode($encrypted), 128) as $chunk) {
openssl_public_decrypt($chunk, $decryptData, $this->public_key_resource);
$crypto .= $decryptData;
}
return $crypto;
}
/**
* 解密 私密钥加密后的密文
*/
// public function public_decrypt($input) {
// openssl_public_decrypt(base64_decode($input),$output,$this->public_key_resource);
// return $input;
// }
/**
* 用公密钥加密
*/
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;
}
}
// $time = time();
// echo '时间戳=='.$time.'<br>';
// $rsa = new rsa('public_key.txt','private_key.txt');
// $str = '撇如惊鸿&'.$time;
// $str = $rsa->public_encrypt($str); //用公密钥加密
// echo '公秘钥加密=='.$str.'</br>';
// $str = $rsa->private_decrypt($str); //用私密钥解密
// echo '私秘钥解密=='.$str.'</br>';
// //=============================================================
// $str = $rsa->private_encrypt($str); //用丝密钥加密
// echo '私密钥加密=='.$str.'</br>';
// $str = $rsa->public_decrypt($str); //用公密钥解密
// echo '公密钥解密=='.$str.'</br>';
php 非对称加密解密类的更多相关文章
- Java常用的加密解密类(对称加密类)
Java常用的加密解密类 原文转载至:http://blog.csdn.net/wyc_cs/article/details/8793198 原创 2013年04月12日 14:33:35 1704 ...
- [C#] 常用工具类——加密解密类
using System; using System.Configuration; using System.Collections.Generic; using System.Text; using ...
- 对接携程供应商php加密解密类
php加密解密类 <?php class Aes{ private $key = '6b4d63211b4ba869'; private $iv = 'dbbf079b95004f65'; pu ...
- PHP针对数字的加密解密类,可直接使用
<?phpnamespace app;/** * 加密解密类 * 该算法仅支持加密数字.比较适用于数据库中id字段的加密解密,以及根据数字显示url的加密. * @author 深秋的竹子 * ...
- Java对称与非对称加密解密,AES与RSA
加密技术可以分为对称与非对称两种. 对称加密,解密,即加密与解密用的是同一把秘钥,常用的对称加密技术有DES,AES等 而非对称技术,加密与解密用的是不同的秘钥,常用的非对称加密技术有RSA等 为什么 ...
- 生成二维码 加密解密类 TABLE转换成实体、TABLE转换成实体集合(可转换成对象和值类型) COOKIE帮助类 数据类型转换 截取字符串 根据IP获取地点 生成随机字符 UNIX时间转换为DATETIME\DATETIME转换为UNIXTIME 是否包含中文 生成秘钥方式之一 计算某一年 某一周 的起始时间和结束时间
生成二维码 /// <summary>/// 生成二维码/// </summary>public static class QRcodeUtils{private static ...
- java文本文件加密解密类
原文:http://www.open-open.com/code/view/1420031154765 import java.awt.*; import java.awt.event.*; impo ...
- AES对称加密解密类
import java.io.UnsupportedEncodingException; import javax.crypto.Cipher; import javax.crypto.spec.Se ...
- CryptoAPI与openssl RSA非对称加密解密(PKCS1 PADDING)交互
(以下代码中都只做测试用,有些地方没有释放内存...这个自己解决下) 1.RSA非对称的,首先提供一个供测试用的证书和私钥的数据 1)pem格式的证书和私钥(公私钥是对应的)的base64编码 voi ...
随机推荐
- [转]bootstrapValidator.js 做表单验证
本文转自:https://www.cnblogs.com/nele/p/5493414.html 作者:@nele本文为作者原创,转载请注明出处:https://www.cnblogs.com/nel ...
- java导出excel时合并同一列中相同内容的行
一.有时候导出Excel时需要按类别导出,一大类下好几个小类,小类下又有好几个小小类,就像下图: 要实现这个也不难, 思路如下:按照大类来循环,如上就是按照张江校区.徐汇校区.临港校区三个大类循环,然 ...
- SpringBoot注解验证参数
SpringBoot注解验证参数 废话不多说,直接上表格说明: 注解 作用类型 解释 @NotNull 任何类型 属性不能为null @NotEmpty 集合 集合不能为null,且size大于0 @ ...
- 云计算的三种服务模式:IaaS, PaaS, SaaS
IaaS: Infrastructure as a Service 基础设施即服务 PaaS: Platform as a Service 平台即服务 SaaS: Software as a Serv ...
- 从零开始学习html(七)CSS样式基本知识
一.内联式css样式,直接写在现有的HTML标签中 <!DOCTYPE HTML> <html> <head> <meta http-equiv=" ...
- Android 2018最新验证手机号正则表达式
/** * 判断字符串是否符合手机号码格式 * 移动号段: 134,135,136,137,138,139,147,150,151,152,157,158,159,170,178,182,183,18 ...
- Elasticsearch5.4署遇到的问题
问题一 can not run elasticsearch as root Elastic 不建议通过root用户启动ES服务器,如果非要用root启动,可以在config/jvm.options配置 ...
- Java:构造代码块,静态代码块
本文内容: 局部代码块 构造代码块 静态代码块 补充 首发日期:2018-03-28 局部代码块: 局部代码块用于限制变量的生命周期,如果希望某些变量在某一过程之后直接失效而不希望被后面继续操作时,可 ...
- JavaScript大杂烩14 - 使用JQuery(上)
JQuery意义 - Why? 为什么要使用JQuery,从我个人来说,就是这么几点:简化代码 + 统一行为 + 功能强大 + 搭配方便. 简化代码是从写代码的角度来说的,实现同样的功能,如果用Jav ...
- JavaScript大杂烩9 - 理解BOM
毫无疑问,我们学习JavaScript是为了完成特定的功能.在最初的JavaScript类型系统中,我们已经分析过JavaScript在页面开发中充当着添加逻辑的角色,而且我们知道JavaScript ...