《深入浅出HTTPS》读书笔记(17):公开密钥算法

公开密钥算法(Public Key Cryptography),也称为非对称加密算法(Asymmetrical Cryptography)。

公开密钥算法的功能比较多,可以进行加密解密、密钥协商、数字签名。

【密钥是一对】

公开密钥算法的密钥是一对,分别是公钥(public key)和私钥(private key),一般私钥由密钥对的生成方(比如服务器端)持有,避免泄露。

【运算速度很慢】

公开密钥算法尤其是RSA算法运算非常缓慢,一般情况下,需要加密的明文数据都非常大,如果使用公开密钥算法进行加密,运算性能会惨不忍睹。

公开密钥算法最重要和最广泛使用的算法就是RSA算法。

【RSA】

该算法是Ron Rivest、Adi Shamir、Leonard Adleman三个人创建的,以三个人名字的首字母命名。

1)密钥文件生成过程

◎选取两个很大的质数p和q。

◎求这两个数的乘积n

◎取一个公开指数e,这个数的值小于(p-1)(q-1), e对应的值和(p-1)(q-1)的值互质。

◎e和n组合起来就相当于公钥。

◎通过e、p、q能够计算出私钥d, d和n组合起来就是私钥。

e和d之间存在互逆的关系。

2)加密过程

RSA算法假如应用于加密,一般使用公钥加密,私钥解密

对明文M进行多次幂运算,运算的次数就是公钥,计算出值后再进行模运算(mod n),最终得到的C就是密文。

  1. 解密过程

对密文进行d次的幂运算,然后进行模运算,最终得到明文M。

至于加密和解密如何互逆,依赖于算法和密钥对,过程如下:

◎C^d的过程相当于(M^e)^d。

◎(M^e)^d相当于M ^(e*d)。

◎(e*d) mod n等于1。

◎C^d (mod n)最终就能反解出M。

相关推荐
hans汉斯5 小时前
基于机器学习的商业银行信贷风险评估系统构建与实证研究
大数据·人工智能·爬虫·算法·yolo·机器学习·支持向量机
普普通通的南瓜5 小时前
金融交易防护:国密 SSL 证书在网银与移动支付中的核心作用
网络·网络协议·安全·arcgis·gitlab·ssl·源代码管理
游戏开发爱好者85 小时前
iOS 抓包工具实战 开发者的工具矩阵与真机排查流程
android·ios·小程序·https·uni-app·iphone·webview
laocooon5238578865 小时前
一个蛇形填充n×n矩阵的算法
数据结构·算法
岑梓铭5 小时前
《考研408数据结构》第六章(5.4树和森林)复习笔记
数据结构·笔记·考研·算法·408·ds
凤年徐5 小时前
Work-Stealing 调度算法:Rust 异步运行时的核心引擎
开发语言·算法·rust
景早6 小时前
力扣1. 两数之和
数据结构·算法·leetcode
AORO20256 小时前
变身智能车载台,AORO P9000U三防平板赋能工业数字化升级
5g·智能手机·电脑·制造·信息与通信·1024程序员节
Blossom.1186 小时前
把AI“灌”进奶瓶:1KB决策树让婴儿温奶器自己学会「恒温+计时」
人工智能·python·深度学习·算法·决策树·机器学习·计算机视觉
2501_938774299 小时前
CCF B 类会议指南:DASFAA 2026 数据挖掘中的公平性与可解释性
1024程序员节