当前位置: 首页 > 编程日记 > 正文

RSA加密传输代码示例

RSA加密传输代码示例

涉及敏感数据的传输,双方最好约定使用加密解密。那RSA非对称加密就大有作为了。
服务端可以保留自己的私钥,发给客户端对应的公钥。这样就可以互相加解密了。php中rsa加解密实现:

首先要生成一对公钥私钥。前提是linux机器上安装了openssl命令。

生成私钥文件:

1openssl genrsa -out rsa_private_key.pem 1024

利用私钥,生成公钥:

1openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

php代码案例:

 1<?php
2ini_set('error_reporting', -1);
3ini_set('display_errors', -1);
4header('Content-Type: text/html; charset=utf-8');
5
6$private_key = file_get_contents("/home/users/xx/test/rsa_private_key.pem");
7$public_key = file_get_contents("/home/users/xx/test/rsa_public_key.pem");
8
9$pi_key = openssl_pkey_get_private($private_key);// 可用返回资源id
10$pu_key = openssl_pkey_get_public($public_key);
11
12// 加密数据
13$data = array(
14    'id' => '1234567890',
15    'name' => '小明',
16    'mobile' => '123456',
17);
18// 转换为JSON格式
19$data = json_encode($data);
20
21$encrypted = '';
22$decrypted = '';
23
24
25// 公钥加密
26openssl_public_encrypt($data, $encrypted, $pu_key);
27// base64传输
28$encrypted = base64_encode($encrypted);
29echo $encrypted, "<br/>";
30
31//私钥解密
32openssl_private_decrypt(base64_decode($encrypted), $decrypted, $pi_key);
33echo $decrypted, "<br/>";
34
35// 打印加密明文
36print_r(json_decode($decrypted, true));
37

公钥加密(openssl_public_encrypt),私钥解密(openssl_private_decrypt)。
私钥加密(openssl_private_encrypt),公钥解密(openssl_public_decrypt)。

都是一个道理,代码类似。RSA加密解密有个填充方式padding的参数,不同编程语言之间交互,需要注意这个。

1padding can be one of OPENSSL_PKCS1_PADDING, OPENSSL_SSLV23_PADDING, OPENSSL_PKCS1_OAEP_PADDING,OPENSSL_NO_PADDING

大于1024字节加密

值得注意的是,如果选择密钥是1024bit长的(openssl genrsa -out rsa_private_key.pem 1024),那么支持加密的明文长度字节最多只能是1024/8=128byte

  • 如果加密的padding填充方式选择的是OPENSSL_PKCS1_PADDING(这个要占用11个字节),那么明文长度最多只能就是128-11=117字节。如果超出,那么这些openssl加解密函数会返回false

  • 这时有个解决办法,把需要加密的源字符串按少于117个长度分开为几组,在解密的时候以172个字节分为几组。
    其中的『少于117』(只要不大于117即可)和『172』两个数字是怎么来的,值得一说。

  • 为什么少于117就行,因为rsa encrypt后的字节长度是固定的,就是密钥长1024bit/8=128byte。因此只要encrypt不返回false,即只要不大于117个字节,那么返回加密后的都是128byte

  • 172是因为什么?因为128个字节base64_encode后的长度固定是172。

  • 这里顺便普及下base64_encodeencode的长度是和原文长度有个计算公式:
    <br />$len2 = $len1%3 &gt;0 ? (floor($len1/3)4 + 4) : ($len14/3);<br />

  • 明文超出长度的代码(前提是1024bit的密钥长,OPENSSL_PKCS1_PADDING的填充方式,否则数字要变化)

 1<?php
2$pi_key =  openssl_pkey_get_private($private_key);// 资源类型
3$pu_key = openssl_pkey_get_public($public_key);
4
5$data = array(
6    'username' => '张三1',
7    'mobile' => '13321995977',
8    'info' => '14bMitESqD4PYwODWmy7rrrvyFPEnJJTECLjvKB7IkrVxVDkp1XiJnGKH  
92h5syHQ5qslPSGYJ1M/XkDnGINwaLVHVD3BoKKgKg1bZn7ao5pXT+herqxaVwWs6  
10ga63yVSIC8jcODxiuvxJnUMQRLaqoF6aUb/2VWc2T5MDmxLhAkEA3pwGpvXgLiWL  
113h7QLYZLrLrbFRuRN4CYl4UYaAKokkAvZly04Glle8ycgOc2DzL4eiL4l/+x/gaq  
12deJU/cHLRQJBANOZY0mEoVkwhU4bScSdnfM6usQowYBEwHYY',
13);
14
15$str = json_encode($data);
16$en = encrypt_rsa($str, $pu_key);
17
18$de = decrypt_rsa($en, $pi_key);
19echo $de;
20
21function encrypt_rsa($data, $pu_key){
22    $split = str_split($data, 100);// 1024bit && OPENSSL_PKCS1_PADDING  不大于117即可
23    foreach ($split as $part) {
24        $isOkay = openssl_public_encrypt($part, $en_data, $pu_key);
25        if(!$isOkay){
26            return false;
27        }
28        // echo strlen($en_data),'<br/>';
29        $encode_data .= base64_encode($en_data);
30    }
31    return $encode_data;
32}
33
34function decrypt_rsa($data, $pi_key){
35    $split = str_split($data, 172);// 1024bit  固定172
36    foreach ($split as $part) {
37        $isOkay = openssl_private_decrypt(base64_decode($part), $de_data, $pi_key);// base64在这里使用,因为172字节是一组,是encode来的
38        if(!$isOkay){
39            return false;
40        }
41        $decode_data .= $de_data;
42    }
43    return $decode_data;
44}
45


转载于:https://www.cnblogs.com/tinywan/p/10179806.html

相关文章:

贪心:assign cookies分糖果

贪心算法的核心&#xff1a; 遵循某种规律&#xff0c;使用最少的资源来完成目标 所以在了解贪心算法的时候需要明确两点 寻找共有的规律每一步的迭代使用最优的策略&#xff08;消耗最少的资源&#xff09; 问题如下&#xff1a; 已知一些孩子和一些糖果&#xff0c;每个孩…

mimo系统matlab,OFDM—MIMO系统的matlab程序

【实例简介】MIMO OFDM Simulator:OFDM.m: OFDM Simulator (outer function)create_channel.m: Generates a Rayleigh fading frequency-selective channel, parametrized by the antenna configuration, the OFDM configuration, and the power-delay profile.svd_decompose_c…

软件行业项目经理主要的职责是什么?(转)

项目经理职责&#xff1a;1、 基本职责就是确保项目目标的实现&#xff0c;领导项目团队准时、优质地完成全部工作。2、 与客户沟通&#xff0c;了解项目的整体需求。并与客户保持一定的联系&#xff0c;即时反馈阶段性的成果&#xff0c;和即时更改客户提出的合理需求。3、 制…

android interview 1

1. 请描述下Activity的生命周期。 必调用的三个方法&#xff1a;onCreate() --> onStart() --> onResume()&#xff0c;用AAA表示&#xff08;1&#xff09;父Activity启动子Activity&#xff0c;子Actvity退出&#xff0c;父Activity调用顺序如下AAA --> onF…

Spring Boot 的 10 个核心模块

学习 Spring Boot 必须得了解它的核心模块&#xff0c;和 Spring 框架一样&#xff0c;Spring Boot 也是一个庞大的项目&#xff0c;也是由许多核心子模块组成的。 你所需具备的基础 告诉你&#xff0c;Spring Boot 真是个牛逼货&#xff01;Spring Boot 核心配置文件详解Sprin…

贪心:Wiggle Subsequence 摇摆序列

一个整数序列&#xff0c;如果两个相邻元素的差恰好正负(负正)交替出现&#xff0c;则该序列被称为 摇摆序列。一个小于2个元素的序列直接为摇摆序列。给一个随机序列&#xff0c;求这个序列满足摇摆序列定义的最长子序列的长度&#xff1a; 输入[1,17,5,10,13,15,10,5,16,8]&…

php 腾讯云实时音视频,腾讯云视频 -实时音视频学习日志

1、实时音视频功能h5只支持ios2、不能主动拉人建群3、pc端的demo研究整体流程可以按照腾讯音视频上面指导的步骤走&#xff0c;申请账号&#xff0c;创建应用&#xff0c;购买套餐。购买好套餐后然后记录sdkappid、accountType。下载密钥。在开发辅助里面有个签名(UserSig)生成…

juery mobile select下来菜单选项提交form问题

注意&#xff1a; data-native-menu"false" 虽然具有渲染作用&#xff0c;但是无法进行js提交。 <script type"text/javascript"> $(function() { $("#category").change(function() { loadData(); }); }); function loadData(){ documen…

android GridView item中组件获取焦点

2019独角兽企业重金招聘Python工程师标准>>> 项目中在使用GridView控件时&#xff0c;里面的item有imageView、buttion等子控件。 但是GridView默认焦点是让item获取焦点&#xff0c;所以要使子控件获取焦点的话&#xff0c;要在gridview的属性中设置&#xff1a; …

Login failed for user 'NT AUTHORITY\SYSTEM'. 原因: 无法打开明确指定的数据库。异常处理...

公司一台SQL Server服务器一直报 "Login failed for user NT AUTHORITY\SYSTEM. 原因: 无法打开明确指定的数据库。"错误&#xff0c;按网上所讲的正常的处理方式都没有解决。 最后是发现一个公司内部人员写的服务造成的&#xff0c;将服务停用即可。转载于:https://…

n-netstat 查看网络状态命令

文章目录前言语法格式输出含义使用实例列出端口占用情况 (包括监听和未监听的)列出所有处于监听状态的 Sockets显示每个协议的统计信息在 netstat 输出中显示 PID 和进程名称在 netstat 输出中不显示主机&#xff0c;端口和用户名 (host, port or user)持续输出 netstat 信息显…

php win memcached 5.4,CentOS 5.4下Memcache的安装步骤(Linux+Nginx+PHP+Memcached) 电脑维修技术网...

一、源码包准备服务器端主要是安装memcache服务器端&#xff0c;目前的最新版本是 memcached-v1.4.4 。下载&#xff1a;http://memcached.googlecode.com/files/memcached-1.4.4.tar.gz另外&#xff0c;Memcache用到了libevent这个库用于Socket的处理&#xff0c;所以还需要安…

LomoX 桌面UI框架更新,增加资源管理

修改&#xff1a; 1.增加lxoption工具类&#xff0c;提供启动的兼容&#xff0c;兼容旧版的&#xff0c;并支持注册资源启动 &#xff08;蔡东赟&#xff09;兼容启动项目&#xff1a;main.lx //资源包默认现在用 qrc:/pack/main.html 后面评估&#xff0c;或者等编辑器出来mai…

Python 数据类型:列表

一、列表介绍 1. 列表可以存储一系列的值&#xff0c;使用中括号来定义&#xff0c;每个元素之间用逗号隔开&#xff0c;形如 [a, b, c, d]2. 列表与元组的区别是&#xff1a;列表中的元素是可变的&#xff0c;元组中的元素是不可变的 In [1]: list1 [] # 定义一个空列…

贪心:remove K digits移除K个数字

问题描述&#xff1a; 已知一个使用字符串表示的非负整数num&#xff0c;将num中的k个数字移 除&#xff0c;求移除k个数字后&#xff0c;可以获得的最小的可能的新数字。 例如&#xff1a;num “1432219” , k 3 在去掉3个数字后得到的很多很多可能里&#xff0c;如1432、43…

oracle 分组排序 update,oracle分组排序

oracle 分组排序&#xff1a;这个麻烦&#xff1a;SELECT * FROM (SELECT deptno,ename,sal,ROW_NUMBER() OVER (PARTITION BY deptno ORDER BY sal DESC ) Top3 FROM emp)WHERE Top3 < 3开窗函数也ok&#xff1a;代码简单点&#xff1a;where 11 and status2JOIN( select p…

QLocalServer与QLocalSocket进程通讯

在Qt中&#xff0c;提供了多种IPC方法&#xff0c;作者所用的是QLocalServer和QLocalSocket。看起来好像和Socket搭上点边&#xff0c;实则底层是windows的name pipe。这应该是支持双工通信的。一 QLocalServer#ifndef VXMAINWINDOW_H#define VXMAINWINDOW_H#include <QWidg…

JDBC编程步骤

JDBC编程步骤 JDBC编程大致按如下步骤进行&#xff1a; &#xff08;1&#xff09;加载数据库驱动。通常我们使用Class类的forName静态方法来加载驱动。例如如下代码&#xff1a; Class.forName(driverClass) driverClass就是数据库驱动类所对应的字符串 例如加载…

(13)中值滤波和双边滤波

其实中值滤波&#xff0c;就是那九个数值&#xff0c;进行排序&#xff0c;选择中间的数值来代替那九个数的中间位置的值&#xff0c;然后再从左到右&#xff0c;从上到下&#xff0c;这样移动运算 下面是均值滤波和高斯滤波的基础知识 中值滤波基础知识 运用中值滤波&a…

贪心:Jump Game 跳跃游戏

一个数组存储了非负整型数据&#xff0c;数组中的第i个元素a[i]&#xff0c;代表了可以从数组第i个 位置最多向前跳跃a[i]步;已知数组各元素的情况下&#xff0c;求是否可以从数组的第0个位置跳跃到数组的最后一个元素的位置&#xff0c;返回是true或者false判断是否能够跳跃到…

MFC之按键消息(长按处理)

想要实现长按键的一些控制&#xff0c;查了查可以通过捕获键盘事件&#xff0c;然后处理按键时需要进行的操作。下面简单的实现左右按键界面更新数值加减。 1. 重载PreTranslateMessage(MSG* pMsg)函数&#xff0c;在函数中捕获键盘事件并处理响应&#xff1a; BOOL CEditTestD…

服务器oracle11g卸载,卸载Oracle11g步骤详解

卸载Oracle11g步骤详解用Oracle自带的卸载程序不能从根本上卸载Oracle&#xff0c;从而为下次的安装留下隐患&#xff0c;那么怎么才能完全卸载Oracle呢&#xff1f;那就是直接注册表清除&#xff0c;步骤如下&#xff1a;1、 开始&#xff0d;>设置&#xff0d;>控制面板…

Fedora下配置网卡

第一次在fedora下配置静态网卡&#xff0c;首先去网络管理里面添加并设置网卡的IP&#xff0c;子网掩码和默认网关出口&#xff0c;然后保存即可&#xff0c; 也可以在 /etc/sysconfig/network-scripts/ifcfg-eth0 中直接添加这些信息&#xff0c;对应的为网卡的IP&#xff0c;…

echarts相关设置

1.显示隐藏工具栏 注释toolbox即可 /* toolbox: {show : true,feature : {dataView : {show: true, readOnly: false},magicType : {show: true, type: [line, bar]},restore : {show: true},saveAsImage : {show: true}}},*/ 2.鼠标划过数据显示对应的数据 tooltip : {trig…

贪心:jump 游戏(获取最少跳跃的次数以及跳跃路径)

一个数组存储了非负整型数据&#xff0c;数组中的第i个元素a[i]&#xff0c;代表了可以从数组第i个 位置最多向前跳跃a[i]步;已知数组各元素的情况下&#xff0c;求是否可以从数组的第0个位置跳跃到数组的最后一个元素的位置&#xff0c;返回最少跳跃的次数以及跳跃过程的路径&…

ADO.NET事务

在发布System.Transaction命名空间之前&#xff0c;可以直接用ADO.NET创建事务&#xff0c;也可以通过组件、特性和COM运行库&#xff08;位于System.EnterpriseServices命名空间中&#xff09;进行事务处理。本文如题所示&#xff0c;介绍在这些传统事务处理方式中较为简单的“…

oracle表中怎么去重复,oracle去掉表重复数据

今天在做项目过程中&#xff0c;碰到数据库表存在重复记录&#xff0c;显示的时候需要去掉重复的数据。想了老半天&#xff0c;最终用rank() over (partition by 分组字段 order by 排序字段 顺序)解决了此问题。一、首先介绍下rank() over (partition by 分组字段 order by 排…

JavaIO操作(1)字节流和字符流-1

3.2、字节流和字符流&#xff08;核心&#xff09; 使用File类执行的所有操作都是针对于文件本身&#xff0c;但是却没有针对于文件的内容&#xff0c;而要进行文件内容操作就需要通过Java之中提供的两组类完成&#xff1a; 字节操作流&#xff08;是在JDK 1.0的时候定义的&am…

7min到40s:SpringBoot 启动优化实践

然后重点排查这些阶段的代码。先看下。

SpringBoot系列教程之Bean之指定初始化顺序的若干姿势

之前介绍了@Order注解的常见错误理解,它并不能指定 bean 的加载顺序,那么问题来了,如果我需要指定 bean 的加载顺序,那应该怎么办呢?本文将介绍几种可行的方式来控制 bean 之间的加载顺序。