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

news2024/11/13 20:46:57

一、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.coloradmin.cn/o/453271.html

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

相关文章

Kali下部署-Nessus漏扫工具

Nessus 是全世界最多人使用的系统漏洞扫描与分析软件。总共有超过75,000个机构使用Nessus 作为扫描该机构电脑系统的软件。 特点: 1、提供完整的电脑漏洞扫描服务,并随时更新漏洞库。 2、可以在本机或者是远端上进行遥控,进行系统的漏洞扫…

深入理解AMQP协议

一.AMQP 是什么 AMQP(Advanced Message Queuing Protocol, 高级消息队列协议)是一个提供统一消息服务的 应用层标准高级 消息队列协议,是 应用层协议的一个 开放标准,为面向消息的中间件设计,是一个进程间传递 异步消息…

线性模型的介绍

一、背景 在一个理想的连续世界中,任何非线性的东西都可以被线性的东西来拟合,所以理论上线性模型可以模拟物理世界中的绝大多数现象。 线性模型(Linear Model)是机器学习中应用最广泛的模型,指通过样本特征的线性组…

生产力提速增效的4大敲门砖

引言: 本文章将分四大板块介绍提高程序员生产力的方案,最大化利用你的IDE ,其中Live Template篇,插件篇非常值的一看, 用好才能提速增效 Productity Guide篇 Postfix Completion篇 Live Template篇 插件篇 Product…

NGFW的protal认证实验

实验topo 用到工具:ensp,kali,cloud云的网段是192.168.43.0;连接cloud的g0/0/0地址就是你登录web,protal的地址 实验说明:建议不在真机上面配置直接用,因为真机不稳定。这里用kali当真机&#x…

【网络应用开发】实验5—— JDBC数据库访问与DAO设计模式

目录 JDBC数据库访问与DAO设计模式预习报告 一、实验目的 二、实验原理 三、实验预习内容 1. JDBC常用的类对象与接口有哪些?它们的功能如何? 2.使用数据源访问数据库的基本思想是什么?这样做有什么好处? 3.什么是DAO&am…

vscode使用虚拟环境

我的conda没有添加入path,每次打开总是报错 一、选择对应虚拟环境的解释器 1.点击vscode的右下角这里 2.点击后可能会在vscode上方出现下图样子,如果出现下图,则点击第二项Select at workspace level, 3.接着出现下图样式&#…

2022年营收破百亿,零跑汽车展现超强实力

此前,零跑已正式公布了2022年的财务数据。可以看到,零跑去年的营收破百亿,增速将近300%,这一成绩在汽车界是相当优越的。说到为何零跑能够实现如此快速的成长,那就不得不提其全域自研的核心优势。 如今,无论…

有始有终的编码原则

基本情况 在程序员的修炼之道之中,说到: 这个建议能简单地应用到大多数场合。简单说就是,分配资源的函 数或对象,对释放资源应负有责任。 这其实就是我们常说的谁分配的就谁负责释放,这也是内存释放的一个原则&#x…

微搭低代码实现投票功能

经常有一类需求,就是投票的功能,需要限制每一个选项每个人只可以投一票,投完之后需要统计票数。本篇教程我们讲解一下如何利用微搭低代码工具来实现投票功能。 1 设计数据源 我们需要设计一个数据源来记录用户的投票,如何限制用…

Docker网络模式详解

文章目录 一、docker网络概述1、docker网络实现的原理1.1 随机映射端口( 从32768开始)1.2 指定映射端口1.3 浏览器访问测试 二、 docker的网络模式1、默认网络2、使用docker run 创建Docker容器时,可以用--net或--network 选项指定容器的网络模式 三、docker网络模式…

代码审计实战3-android java

jks java keystore 作用:保证应用的唯一性 简介:可以理解为java的密钥库,是一个用来存放密钥和证书的仓库。 (而keytool就是密钥和证书的管理工具,它把key(密钥)和certificate(证…

一零五六、Jsp+mysql 实现学生选课系统(附源码及数据库)

目录 实现效果 项目代码 数据库 结语 实现效果 login.jsp index.jsp course_query.jsp course_selection.jsp course_withdraw.jsp selection_query.jsp 项目代码 checkSelectionStatus.jsp % page contentType"text/html;charsetUTF-8" language"java&q…

图像处理:均值滤波算法

目录 前言 概念介绍 基本原理 Opencv实现中值滤波 Python手写实现均值滤波 参考文章 前言 在此之前,我曾在此篇中推导过图像处理:推导五种滤波算法(均值、中值、高斯、双边、引导)。这在此基础上,我想更深入地研…

4月23号软件更新资讯合集.....

微软发布 Web 渲染引擎 Babylon.js 6.0 Babylon.js 是一个强大、简单、开放的游戏和 Web 渲染引擎,并被封装在一个友好的 JavaScript 框架中。 Babylon.js 6.0 带来了性能改进、渲染增强和一系列新功能。 新物理插件 Havok 团队通过一个特殊的新 WASM 插件和对 Ba…

sar基本命令格式操作及使用方法学习笔记

目录 SAR说明Centos7安装Sar命令sar命令显示时间改为24小时制查询某天某个时间段内的数据 SAR说明 sar是一个采集,报告和存储计算机负载信息的工具。自下载安装好后每10分钟对系统性能进行一次采集,每天的日志文件保存再/var/log/sa/下,sa17…

Docker 部署Redis

由于项目需要,上了redis。公司用的是OKD4.x,所以在自己的环境上也直接上docker,比下载、编译、安装省心多了。 1、下载镜像 官网地址:https://hub.docker.com/_/redis 我选择的是docker pull redis:7.0-bullseye 具体版本号的含…

Web3D包装生产线 HTML5+Threejs(webgl)开发

生产线三维可视化解决方案就是通过物联网、虚实联动和三维建模等先进技术,以一个3D立体模型展现出来,可以让我们很直观的看到生产线的运作以及对数据的监控。3D运用数据孪生技术可以让工业3D物联网管理系统的界面变得非常的简单易看,并且能够…

软件测试的新技术和方法

作为一位资深的IT领域博主,我一直在关注软件测试领域的发展趋势。随着技术的不断发展,软件测试领域也在不断更新换代。在本文中,我将分享一些最新的软件测试技术和方法,希望能对广大软件测试工程师提供一些参考。 一、自动化测试…

【教程】保姆级红米AX6000刷UBoot和OpenWrt固件

转载请注明出处:小锋学长生活大爆炸[xfxuezhang.cn] 目录 开启SSH 刷入UBoot 刷入Openwrt 设置Openwrt 刷回小米原厂固件 开启SSH 1、下载官方指定版本固件:https://share.qust.me/redmi-ax6000-1.2.8.bin 2、进入路由器后台升级固件:h…