密码技术 (2) - 公钥密码

一. 前言

        公钥密码的秘钥分为加密秘钥和解密秘钥,加密秘钥成为公钥,解密秘钥成为私钥,公钥和私钥的成对存在的,一对公钥和私钥称为密钥对。发送消息时,发送者用公钥对消息进行加密,接收者用私钥进行解密。从这里可以知道,发送者只需要用公钥对消息进行加密,而接收者用私钥解密即可,这样就解决了对称密码的秘钥传送问题。公钥可以通过任何方式公开,但是接收者的私钥是绝对不能被别人知道的。

        由于加密的密码和解密的密码不同,与公钥密码相对的,公钥密码也被称为非对称密码。下面介绍公钥密码相关的几种加密算法。

二. 加密算法

1. RSA

        RSA这种公钥密码算法是由三位开发者完成,分别是Ron Rivest,Adi Shamir和Leonard Adleman。而RSA名字就是分别取自三人的姓的首字母。

        对于RSA在数学上的具体实现,这里不做探究

2. EIGamal

        EIGamal算法是由Taher EIGamal设计的,EIGamal相对于RSA有一个缺点,经过加密的密文长度会变为明文的两倍

三. openssl实践

        openssl通过genrsa,rsa和rsautl选项用于公钥密码,genrsa用于生成公钥和私钥,rsa用于处理rsa秘钥,例如由私钥生成公钥,rsautl是rsa的一些工具,例如加密解密。下面介绍生成私钥和公钥的方法以及利用公钥私钥加密和解密数据步骤:

1. 生成私钥

openssl genrsa -out private.pem 2048

        生成2048长度的私钥。 

2. 由私钥生成公钥

openssl rsa -in private.pem -pubout -out public.pem

3. 由公钥加密数据

infile内容:

ni hao,rsa

加密操作:

openssl rsautl -encrypt -pubin -inkey public.pem -in infile -out outfile

outfile内容:

00000000  29 44 23 c6 10 14 65 58  75 0d f7 ef f1 6e 77 9b  |)D#...eXu....nw.|
......
000000f0  10 a7 82 16 fd 44 dc d5  1b 3c ca a1 16 79 22 54  |.....D...<...y"T|

4. 由私钥解密数据

解密操作:

openssl rsautl -decrypt -inkey private.pem -in outfile -out decryptfile

decryptfile内容:

ni hao,rsa

四. 总结

        公钥密码对于对称密码是解决了秘钥的传送问题,公钥无法解密公钥加密的数据,只有私钥可以,所以任何人都可以获得公钥。不过公钥密码还存在一个问题,发送者不能确定公钥和接收者的私钥是密钥对,公钥可能被篡改,导致使用了中间攻击人的公钥,导致安全问题。

        除RSA算法外,公钥密码的算法还有,Rabin和椭圆曲线密码(ECC)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/91801.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

golang官方限流器rate

包名&#xff1a;golang.org/x/time/rate 实现原理&#xff1a;令牌桶 package mainimport ("context""fmt""testing""time""golang.org/x/time/rate" )func TestLimiter(t *testing.T) {// 第一个参数代表速率&#xff1…

工厂与观察者模式

工厂模式介绍 通过一个加工厂&#xff0c;在这个工厂中添加对应材料&#xff0c;我们就可以得到想要的东西&#xff0c;在程序设计中&#xff0c;这种模式就叫做工厂模式&#xff0c;工厂生成出的产品就是某个类的实例&#xff0c;也就是对象。 关于工厂模式一共有三种&#…

小程序与uniapp如何进行传参

小程序和uniapp都可以通过以下方式进行传参&#xff1a; query参数传递&#xff1a;在url中添加query参数&#xff0c;如在小程序中通过wx.navigateTo或wx.redirectTo跳转页面时可传递query参数&#xff0c;在uniapp中通过uni.navigateTo或uni.redirectTo跳转页面时也可以传递q…

Qt::图层框架-图片图层-序列图层-QGraphicsPixmapItem

二维矢量动画智能制作软件开发合集 链接&#xff1a;软件开发技术分享及记录合集 个人开发二维矢量动画智能制作软件界面如下&#xff1a; 目录 一、图片序列图层原理 二、图片序列图层代码实现 三、图片序列图层软件测试视频 结束语 一、图片序列图层原理 本软件的11种…

C++11(列表初始化,声明,范围for)

目录 一、列表初始化 1、一般的列表初始化 2、容器的列表初始化 二、声明 1、 auto 2、decltype 3、nullptr 三、 范围for 一、列表初始化 1、一般的列表初始化 在C98中&#xff0c;标准允许使用花括号{}对数组或者结构体元素进行统一的列表初始值设定。 int main() {…

【OpenCV-Torch-dlib-ubuntu】Vm虚拟机linux环境摄像头调用方法与dilb模型探究

前言 随着金秋时节的来临&#xff0c;国庆和中秋的双重喜庆汇聚成一片温暖的节日氛围。在这个美好的时刻&#xff0c;我们有幸共同迎来一次长达8天的假期&#xff0c;为心灵充电&#xff0c;为身体放松&#xff0c;为未来充实自己。今年的国庆不仅仅是家国团聚的时刻&#xff…

scala基础入门

一、Scala安装 下载网址&#xff1a;Install | The Scala Programming Language ideal安装 &#xff08;1&#xff09;下载安装Scala plugins &#xff08;2&#xff09;统一JDK环境&#xff0c;统一为8 &#xff08;3&#xff09;加载Scala &#xff08;4&#xff09;创建工…

LabVIEW学习笔记五:错误,visa关闭超时(错误-1073807339)

写的串口调试工具&#xff0c;其中出现了这个错误 这是串口接收的部分&#xff0c;如果没有在很短的时间内收到外界发进来的数据&#xff0c;这里就会报错。 先在网上查了一下&#xff0c;这个问题很常见&#xff0c;我找到了官方的解答&#xff1a; VISA读取或写入时出现超时…

【JavaEE】CSS

CSS 文章目录 CSS语法引入方式内部样式表行内样式表外部样式 选择器基础选择器标签选择器类选择器id选择器通配符选择器 复合选择器后代选择器伪类选择器链接伪类选择器 字体设置设置文本颜色粗细样式文本对齐 背景背景颜色背景平铺背景尺寸 圆角矩形元素显示模式块级元素 盒模…

Pikachu靶场——XXE 漏洞

文章目录 1. XXE1.1 查看系统文件内容1.2 查看PHP源代码1.3 查看开放端口1.4 探测内网主机 1. XXE 漏洞描述 XXE&#xff08;XML External Entity&#xff09;攻击是一种利用XML解析器漏洞的攻击。在这种攻击中&#xff0c;攻击者通过在XML文件中插入恶意实体来触发解析器加载…

计算机图像处理-高斯滤波

高斯滤波 高斯滤波是一种线性平滑滤波&#xff0c;适用于消除高斯噪声&#xff0c;广泛应用于图像处理的减噪过程。通俗的讲&#xff0c;高斯滤波就是对整幅图像进行加权平均的过程&#xff0c;每一个像素点的值&#xff0c;都由其本身和邻域内的其他像素值经过加权平均后得到…

1340. 跳跃游戏 V;2039. 网络空闲的时刻;2767. 将字符串分割为最少的美丽子字符串

1340. 跳跃游戏 V 核心思想&#xff1a;动态规划记忆化搜索。定义dfs(i)&#xff0c;表示从i开始最多可以访问多少个下标&#xff0c;然后统计往左跳和往右边跳的最大值&#xff0c;思路其实比较简单&#xff0c;但是代码我感觉还是不太好想。 2039. 网络空闲的时刻 核心思想…

W5100S_EVB_PICO快速入门之MQTT篇(十二)

目录 1. 前言 2. MQTT介绍 2.1 什么是mqtt&#xff1f; 2.2 特点 2.3 应用场景 2.4 MQTT协议实现方式 3. 硬件及接线方式 3.1 硬件准备 3.2 硬件介绍 3.3 接线图 4. 测试 4.1 MQTT测试流程图 4.2 相关代码 4.3 测试现象 5. 相关链接&#xff1a; 1. 前言 随着物…

蓝桥等考Python组别十级002

第一部分:选择题 1、Python L10 (15分) 已知s = Good Luck,下列说法正确的是( )。 s[0]对应的字符是os[2]对应的字符是os[-1]对应的字符是cs[4]对应的字符是L正确答案:B 2、Python L10 (15分) 运行下面程序,输入字符串“pencil”,输出的结果是

vue下载在前端存放的pdf文件

vue下载在前端存放的pdf文件 注意&#xff0c;这里要在public文件夹中新建文件夹存放静态资源&#xff0c;不能在src文件夹中新建文件夹存放静态资源&#xff0c;因为public文件夹中的文件资源不会被npm run build打包编译。大家打包一下&#xff0c;就会发现 模板.pdf文件 是存…

【C++入门指南】类和对象(上)

【C杂货店】类和对象&#xff08;上&#xff09; 一、面向过程和面向对象初步认识二、类的引入三、类的定义四、类的访问限定符及封装4.1 访问限定符4.2 封装 五、类的作用域六、类的实例化七、类对象模型7.1 类对象的存储规则7.2 例题7.3结构体内存对齐规则 八、this指针8.2 t…

R语言对加载的数据归一化

# 自定义归一化函数 custom_normalize <- function(x) {# 在这里编写你的归一化逻辑normalized <- (x - min(x)) / (max(x) - min(x))return(normalized) }# 加载CSV数据 data <- read.csv("your_data.csv", header TRUE)# 应用自定义归一化函数 data_scal…

Spring Boot集成redis集群拓扑动态刷新

项目场景&#xff1a; Spring Boot集成Redis集群&#xff0c;使用lettuce连接Cluster集群实例。 问题描述 redis其中一个节点挂了之后&#xff0c;springboot集成redis集群配置信息没有及时刷新&#xff0c;出现读取操作报错。 java.lang.IllegalArgumentException: Connec…

第 114 场 LeetCode 双周赛题解

A 收集元素的最少操作次数 模拟: 反序遍历数组&#xff0c;用一个集合存当前遍历过的不超过 k k k 的正数 class Solution { public:int minOperations(vector<int> &nums, int k) {unordered_set<int> vis;int n nums.size();int i n - 1;for (;; i--) {if…

CentOS 8开启bbr

CentOS 8 默认内核版本为 4.18.x&#xff0c;内核版本高于4.9 就可以直接开启 BBR&#xff0c;所以CentOS 8 启用BBR非常简单不需要再去升级内核。 开启bbr echo "net.core.default_qdiscfq" >> /etc/sysctl.conf echo "net.ipv4.tcp_congestion_contro…