Python数据结构与算法-RAS算法(p96)

news/2024/4/29 3:25:52/文章来源:https://blog.csdn.net/little_limin/article/details/130311866

一、RSA加密算法简介

1、加密算法概念

  • 传统密码: 加密算法是秘密的

  • 现代密码系统:加密算法是公开的,密钥是秘密的;(密钥可能是随机生成的,与他人不一致)

  • 对称加密—加密和解密用的同一个密钥

  • 非对称加密—加密和解密用的两个密钥,RSA算法属于非对称加密

2、RSA加密算法

  • RSA非对称加密系统:

  • 公钥:用来加密,是公开的 (一般用来加密)

  • 私钥:用来解密,是私有的 (个人用于解密)

  • 例如:

上图所示,Bob用公钥加密M文件,Bob传送给Alice。传送过程中,窃密者窃取M文件得到的加密后的信息,无法解读。Alice使用私钥解读M文件。

二、RSA算法的加密过程

1、RSA加密算法密钥获取过程

  • 随机选取两个质数p和q;

  • 计算n=pq

  • 选取一个与互质的小奇数e,=(p-1)(q-1)

  • 对模,计算e的乘法逆元d,即满足(e*d) mod = 1

  • 公钥(e,n) 私钥(d, n)

2、RSA加密算法密钥获取演示

(1)随机选取两个质数p和q;

质数是指约数只有1和本身的数。

质数越大,密码破解难度越大,实际中的质数是很大的。

>>> p = 53
>>> q = 59

(2)计算n=pq

>>> n = p*q
>>> n
3127

(3)选取一个与互质的小奇数e,=(p-1)(q-1)

互质是指最大公约数为1,奇数是与偶数相对的数,不能被2整除。

>>> fai = (p-1)*(q-1) #fai(n)
>>> fai
301
>>> e = 3

(4)对模,计算e的乘法逆元d,即满足(e*d) mod = 1

找到一个d,满足(e * d) mod = 1(可运用费马小定理,欧几里得算法求解)

>>> d = 2011 # 这里对应的d是2011,可用费马定理求解(具体求解可自行学习)
>>> (e * d) % fai
1

(5)公钥(e,n) 私钥(d, n)

>>> e
3
>>> n
3127
>>> d
2011

公钥:(3, 3127); 私钥(2011,3027)

3、加密解码过程

  • 加密过程: c=(m^e)mod n (公钥)

  • c:密文

  • m:明文

  • n^e: n的e次方,在python中是n ** e

  • 解密过程: m =(c^d)mod n (密钥)

(1)加密过程(终端运行)

>>> m = 87 # 明文
>>> c = (m ** e)%n # 加密
>>> c # 密文
1833

(2)解密过程(终端运行)

>>> (c ** d)%n
87 # 明文

三、RSA加密算法中求乘法逆元

1、乘法逆元定理

由于除法无法直接求模,转化为乘法再求模。

例如:

  • 普通除法下: 14 / 4 = 7 / 2 = 7 x 1/2 = ,将除法转化为乘法。

  • 在该式子下再取模就是模的除法:(14 / 4)mod 5 = (7 x 1/2) mod 5 =() mod 5

  • 乘法逆元类似与倒数的概念,两数相乘1,() mod 5 中取模的数一定为整数,所以1/2需要被整数替换。

  • 因为(2 * 3) mod 5 =1, 则2和的乘法逆元为3。可以用3替换1/2

  • () mod 5 = (7 x 3) mod 5 =21 mod 5 = 1。理解为,7乘以“2的乘法逆元”模5。

乘法逆元定义:设aZ, nN, 如果az 1 (mod n) ,称z是模n下a的乘法逆元,记作

其中: a的乘法逆元是,z的乘法逆元

注意1:模n下互为乘法逆元,一般只考虑比n小的数。

注意2:a在模n内的乘法逆元)是唯一的。也可能就是本身。

注意3:乘法逆元存在条件:gcd(a,n) = 1(最大公约数) ,即模n下,a有乘法逆元。也就是说a 和n互质。

2、用扩展欧几里得算法求乘法逆元

(1)扩展欧几里得算法

给出正整数a和b,扩展的欧几里得算法可以计算a和b的最大公约数d,同时得到两个符号相反的整数x和y满足:d=gcd(a, b) = ax+by。

(2)根据扩展欧几里得算法求乘法逆元

az 1 (mod n) 求模的乘法逆元,又可以写成(a * z)mod n = 1,其中a和n互为质数,gcd(a,n)=1。

(可以得到a * z= y * n +1,这里的y是求解(a * z)mod n = 1中的系数。例如:(7 * 8)mod 11 =1,计算过程,7 * 8 = 5 * 11 + 1,这里的y是5。)

根据扩展欧几里得算法,即得到ax + by = gcd(a, b) = 1。整个求解的过程就是使用欧几里得算法gcd(a,b) = gcd(b, a mod b),求两个数的公约数,一直计算到1为止即可。例如:

  • a = 5,b = 14

14 % 5 =14 - 5 * 2 = 4

5 % 4 = 5 - 4 * 1 = 1 = gcd(a,b)

往回推算:4 = 14 - 5 * 2 替换

5 - (14 - 5* 2) = 1

5 - 14* 1+ 5* 2 =1

5*3 - 14*1 =1

此时x=3,y =1。但是y不是所求的。

则3 是 5 mod 14 的逆元。

  • 当由于式子是奇数个,所以最后整理时a的系数为负:

a =5, b = 18

18 % 5 = 18 - 5 * 3 = 3

5 % 3 = 5 - 3*1 = 2

3 % 2 = 3 - 2 * 1 =1

倒回去:

3-(5 - 3 * 1)=1

18 - 5 * 3 -(5 - 18 + 5 * 3)= 18 - 5 * 3 -5 * 4 + 18 = 18 * 2 - 5 * 7=1

转化为5*(-7)+ 18 * 2 = 1

利用两个数互质的性质以及最小公倍数,我们可以直接得到想要的结果:

5*(-7)+ 18 * 2 = 5 * (-7) mod 18 = 5 * (18-7)mod 18 = 5 * 11 mod 18 =1

最终x= 11.

(欧几里得算法求逆元的代码实现暂时略)

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

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

相关文章

客户端请求耗时严重原因排查优化 (Nginx导致)

客户端请求耗时严重,初步从几个方面进行排查 1.检查网络连接,是否实现丢包,网络波动,网络拥堵等问题。 2.检查客户端请求耗时和project api 接口耗时差异,判断是nginx问题还是接口问题 如果是nginx耗时导致&#xff0c…

用CentOS服务器自己搭建部署个Discuz论坛网站,网站搭建教程

Linux系统CentOS服务器使用堡塔搭建论坛网站全套教程。服务器大本营,技术文章内容集合站发车啦! 操作系统:Centos 7.6 网站程序:Discuz-X3.4 前言 首先,搭建一个网站需要准备:服务器、域名、网站程序。 …

php使用tcpdf,通过html生成的pdf文件,合同章(图片)错位?需要怎么解决

php使用tcpdf,通过html生成的pdf文件,合同章有错位?需要怎么解决? 1、html下的排版正确,如图: 2、html代码,如图 3、生成pdf后的文件,如图 $pdf->Image(),计算一下x、…

如何利用工时表来帮助项目管理做得更完善?

项目管理是一项复杂的任务,需要协调各种资源以确保项目按时交付。其中一个关键方面是管理各个员工工时。工时表软件是一种可以帮助企业记录各个员工工作时效的工具,而且还可以帮助项目管理者记录和跟踪项目成员的时间。那么如何利用工时表来帮助项目管理…

贝叶斯学习(Bayesian Learning)基础篇

Bayesian Learning 前言Motivation and IntroductionThink about Spam Filtering.先验概率后验概率似然度边际概率 Basic assumptionRelevancePractical diculties Bayes TheoremProbability: random eventsBayesian Learning Maximum A Posteriori HypothesisBayes Optimal Cl…

Java核心技术 卷1-总结-9

Java核心技术 卷1-总结-9 使用异常机制的技巧为什么要使用泛型程序设计定义简单泛型类泛型方法类型变量的限定 泛型类型的继承规则 使用异常机制的技巧 1.异常处理不能代替简单的测试。 使用异常的基本规则是:只在异常情况下使用异常机制。 2.不要过分地细化异常。…

人机交互有哪些SCI期刊推荐? - 易智编译EaseEditing

以下是几个人机交互领域的SCI期刊推荐: ACM Transactions on Computer-Human Interaction (ACM TOCHI): 由ACM(Association for Computing Machinery)出版的人机交互领域的顶级期刊之一,发表关于计算机和人之间相互作…

简单聊下HBase

大家好,我是易安! Google发表了三篇论文,即GFS、MapReduce和BigTable,被誉为“三驾马车”,开启了大数据时代。今天我们来聊一下BigTable对应的NoSQL系统HBase,看看它是如何处理海量数据的。 在计算机数据存…

客户体验的重要性和企业发展的紧密联系

近年来,随着企业数字化转型的加速,客户服务的意义越来越被人们所重视。客户服务的质量不仅直接影响到客户满意度和忠诚度,而且会间接影响到企业的品牌口碑和市场竞争力。然而,目前市面上的很多企业帮助中心搭建平台,可…

Point cloud tools for Matlab(点云学习工具)

Point cloud tools for Matlab (tuwien.ac.at)https://www.geo.tuwien.ac.at/downloads/pg/pctools/pctools.html#PointCloud_class 下载:Download Matlab Code 添加路径 addpath(genpath(D:\MyMatlabCode\pointCloudTools)); pc pointCloud(Lion.xyz); pc.plot…

redis入门必会知识

Redis基础知识目录 5、sortedSet 文章目录 系列文章目录前言一、pandas是什么?二、使用步骤 1.引入库2.读入数据总结 前言 一、redis是什么? Redis(Remote Dictionary Server ),即远程字典服务 ! 是一个开源的使用ANSI C语言编写…

Python 查看数据常用函数

Python 查看数据常用函数(以 iris 数据集为例) 1、查看前后几行数据:head 和 tail2、查看数据基本信息:info3、查看数据统计信息:describe 查看数据可以用很多函数,这里就挑选几个最常用的进行简单展示&…

除了学历,你更需要有能力

遥想当年,家里培养出一个大学生,是多荣耀的事!可现今却处于一个比较尴尬的状态。 为什么大学生贬值得这么厉害?其实大学生之所以会不值钱不外乎三大原因:量大、与企业需求不匹配、质量差。 高校扩招下,大…

分布式系统反向代理设计与正向代理

反向代理与正向代理分析 代理服务器:位于发起请求的客户端与原始服务器端之间的一台跳板服务器,代理服务器分为正向代理服务器和反向代理服务器 正向代理 :代理客户端,隐藏了真实的请求客户端,服务端不知道真实的客户…

数据库系统概论--第五章课后习题

1.什么是数据库的完整性? 答:数据库的完整性是指数据的正确性和相容性。 2. 数据库的完整性概念与数据库的安全性概念有什么区别和联系? 答: 数据的完整性和安全性是两个不同的概念,但是有一定的联系。前者是为了防止数据库中存…

TortoiseSVN使用-授权访问

文章目录 3.4.6 授权访问 3.4.6 授权访问 总结: 如果是匿名访问(就是不用输入用户名密码的访问方式),请只开启anon-access write如果授权访问,请先设置anon-access none,然后打开3个:auth-a…

JDBC操作数据库

数据库介绍 数据库是一种存储结构,允许使用各种格式输入、处理和检索数据,不必再每次需要数据时重新输入。当前比较流行的数据库主要有MySQL、Oracle、SQL Server等 使用JDBC操作数据库,SQL语句是比不可少的,SQL是一种结构化查询…

自媒体必备素材库,免费、商用,赶紧马住~

自媒体经常需要用到各类素材,本期就给大家安利6个自媒体必备的素材网站,免费、付费、商用都有,建议收藏起来~ 1、菜鸟图库 https://www.sucai999.com/video.html?vNTYwNDUx 菜鸟图库可以找到设计、办公、图片、视频、音频等各种素材。视频素…

集群聊天服务器项目(三)——负载均衡模块与跨服务器聊天

负载均衡模块 为什么要加入负载均衡模块 原因是:单台服务器并发量最多两三万,不够大。 负载均衡器 Nginx的用处或意义**(面试题)** 把client请求按负载算法分发到具体业务服务器Chatserver能和ChatServer保持心跳机制&#xf…

深入浅出JS定时器:从setTimeout到setInterval

前言 当谈到 JavaScript 编程语言最基本的概念时,定时器就是一个必须掌握的知识点。在编写网站时,你经常会遇到需要在一定时间间隔内执行一些代码的情况。这时候,JavaScript 定时器就可以派上用场了。 什么是定时器? JS 定时器是…