雅荷心语博客
雅荷心语
心之所向便是光
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 首页
  • 前端之旅
  • 后端之路
  • 软件工具
  • 心灵鸡汤
  • 心路历程
  • 视频资料
  • 关于我们
    • 关于我
    • 关于我
  • 微信平台
    • 业务合作
  • 关注本站
    • 微信
    • 微博
    • 腾讯微博
    • Twitter
    • Facebook
    • RSS订阅
Hi, 请登录     我要注册     找回密码

PHP 非对称加密 openssl 加密及解密方法

2016-05-17 分类:后端之路 阅读(2489) 评论(2)
00:00/00:00

首先我们需要使用 http://blog.he29.com/?p=484 生成 公钥和私钥;

然后放进自己的项目,下面是具体代码:
我们载入私钥和公钥,然后判断是否可以使用.

1
2
3
4
5
$path = $_SERVER['DOCUMENT_ROOT'].'/common/extend/Rsa/';
$private_key = file_get_contents($path.'s.txt');//私钥
$public_key = file_get_contents($path.'g.txt');//公钥
$pi_key = openssl_pkey_get_private($private_key);//这个函数可用来判断私钥是否是可用的
$pu_key = openssl_pkey_get_public($public_key);//这个函数可用来判断公钥是否是可用的

接下来,我们准备原始数据,开始操作加密解密

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
$data = "天明宝宝";//原始数据
        $encrypted = "";
        $decrypted = "";
        echo "下面使用私钥进行加密:\n";
        echo "<br/>";
        echo "原始数据=>", $data, "\n";
        echo "<br/>";
        openssl_private_encrypt($data, $encrypted, $pi_key);//私钥加密
        $encrypted = base64_encode($encrypted);//加密后的内容通常含有特殊字符,需要编码转换下,在网络间通过url传输时要注意base64编码是否是url安全的
        echo "加密后的数据:=>". $encrypted, "\n";
        echo "<br/>";
        echo "解密现在的数据为:\n";
        openssl_public_decrypt(base64_decode($encrypted), $decrypted, $pu_key);//私钥加密的内容通过公钥可用解密出来
        echo $decrypted, "\n";
        echo "<br/>";
        echo "---------------------------------------\n";
        echo "<br/>";
        echo "下面使用公钥进行加密:\n";
        echo "<br/>";
        openssl_public_encrypt($data, $encrypted, $pu_key);//公钥加密
        $encrypted = base64_encode($encrypted);
        echo "加密后的数据:=>".$encrypted, "\n";
        echo "<br/>";
        echo "使用私钥进行解密:\n";
        openssl_private_decrypt(base64_decode($encrypted), $decrypted, $pi_key);//私钥解密
        echo $decrypted, "\n";

结果如图:

6

整理成一个类


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
<?php
namespace common\extend;
class Rsa{
    public $private_key;//私钥
    public $public_key;//公钥
    public function __construct(){
        $path = $_SERVER['DOCUMENT_ROOT'].'/common/extend/Rsa/';
        $private_key = file_get_contents($path.'s.txt');
        $public_key = file_get_contents($path.'g.txt');
        $pi_key = openssl_pkey_get_private($private_key);//这个函数可用来判断私钥是否是可用的
        $pu_key = openssl_pkey_get_public($public_key);//这个函数可用来判断公钥是否是可用的
        if($pi_key && $pu_key){
            $this->private_key = $pi_key;
            $this->public_key = $pu_key;
        }else{
            return '公钥或者私钥不可用,请检查';
        }
    }
 
    /**
     * @param $data 公钥加密
     * @return string 传入需要加密的字符串
     */
    public function public_encode($data){
        $encrypted = "";
        openssl_public_encrypt($data, $encrypted, $this->public_key);//公钥加密
        $encrypted =  base64_encode($encrypted);
        return $encrypted;
    }
 
    /**
     * @param $encrypted 使用私钥解密
     * @return string 传入被加密的base64字符串
     */
    public function private_decode($encrypted){
        $decrypted = "";
        openssl_private_decrypt(base64_decode($encrypted), $decrypted, $this->private_key);//私钥加密的内容通过公钥可用解密出来
        return $decrypted;
    }
 
    /**
     * @param $data 私钥加密
     * @return string 传入数据
     */
    public function private_encode($data){
        $encrypted = '';
        openssl_private_encrypt($data, $encrypted,  $this->private_key);//私钥加密
        $encrypted = base64_encode($encrypted);//加密后的内容通常含有特殊字符,需要编码转换下,在网络间通过url传输时要注意base64编码是否是url安全的
        return $encrypted;
    }
 
    /**
     * @param $encrypted 公钥解密
     * @return mixed 传入被加密的字符串
     */
    public function public_decode($encrypted){
        $decrypted = '';
        openssl_public_decrypt(base64_decode($encrypted), $decrypted,  $this->public_key);//私钥加密的内容通过公钥可用解密出来
        return $decrypted;
    }
}

喜欢 (1) 赏 讨厌 (0)
分享到:更多 ()

相关推荐

  • nginx 负载均衡初了解
  • 关于代码自动更新的一次实验
  • 关于 mysql 怎么安装审计插件的记录
  • 自用phpstorm破解补丁
  • 三种微信小程序VR实现方法
  • 使用ffmpeg.wasm在前端html网页上压缩视频解决方案
  • 要SSR? NUXT项目从初始化到部署服务器流程全记录
  • 制作抖音照片会唱歌-吗咿呀嘿, 除了使用Avatarify,现在官方也出滤镜支持了

评论 2

取消

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #1

    构造函数里的判断 用异常机制可能更好一些

    Dawn7年前 (2016-05-17)回复
    • try cache 么

      天明宝宝7年前 (2016-05-17)回复
关于我

小天明 北京·朝阳 前端搬砖工程师

碎碎念):(来自公众号)

热门文章

  • 踩坑记录——iphone上safari开启隐身模式时localStorage变为只读-雅荷心语博客踩坑记录——iphone上safari开启隐身模式时localStorage变为只读2017-02-21评论(4)
  • 程序员是怎样一群人-雅荷心语博客程序员是怎样一群人2015-12-08评论(3)
  • vcard - 二维码名片的格式及扫码导入-雅荷心语博客vcard – 二维码名片的格式及扫码导入2016-05-05评论(2)
  • PHPStorm10 下载安装破解汉化-雅荷心语博客PHPStorm10 下载安装破解汉化2015-12-15评论(2)
  • call_user_func_array 这个函数什么时候用-雅荷心语博客call_user_func_array 这个函数什么时候用2016-09-02评论(2)
2023年3月
一 二 三 四 五 六 日
« 一    
 12345
6789101112
13141516171819
20212223242526
2728293031  

最新评论

  • 前端小武 6年前 (2017-04-06)说:
    我看到了layer
  • 丁艳平 6年前 (2017-03-03)说:
  • Dawn 7年前 (2016-09-16)说:
    call_user_func_array最后的例子是错哦,你用bc方法去调用类里 另外一个方法就知道问题所在了。情况1.调用非静态方法 第一个参数应该传[类的实例,调用方法] (既然有类实例了直接-&
  • Dawn 7年前 (2016-06-21)说:
    tp框架设置了全局捕获异常的,这也没什么。坑的是 他捕获了异常。然后全部返回404。。。不知道的 还以为自己网站被删除了
  • Dawn 7年前 (2016-05-17)说:
    构造函数里的判断 用异常机制可能更好一些

左邻右舍

  • Brian's Blog
  • 易水寒
  • 楼教主
  • 贤心
  • 阿米龙

雅荷心语博客 -心之所向便是光

联系我们关于我们

© 2023 雅荷心语博客   网站地图

emlogdux_heademlogdux_footer