miller_rabin算法检测生成大素数的RSA算法实现
import math
from functools import reduce #用于合并字符
from os import urandom #系统随机的字符
import binascii #二进制和ASCII之间转换 #===========================================
def Mod_1(x,n):
'''取模负1的算法:计算x2= x^-1 (mod n)的值,
r = gcd(a, b) = ia + jb, x与n是互素数'''
x0 = x
y0 = n
x1 = 0
y1 = 1
x2 = 1
y2 = 0
while n != 0:
q = x // n
(x, n) = (n, x % n)
(x1, x2) = ((x2 - (q * x1)), x1)
(y1, y2) = ((y2 - (q * y1)), y1)
if x2 < 0:
x2 += y0
if y2 < 0:
y2 += x0
return x2
#===========================================
def Fast_Mod(a,p,m):
'''快速取模指数算法:计算 (a ^ p) % m 的值,可用pow()代替'''
a,p,m=int(a),int(p),int(m)
if (p == 0) :
return 1
r = a % m
k = 1
while (p > 1):
if ((p & 1)!=0):
k = (k * r) % m
r = (r * r) % m
p >>= 1
return (r * k) % m
#===========================================
def randint(n):
'''random是伪随机数,需要更高安全的随机数产生,
所以使用os.urandom()或者SystmeRandom模块,
生成n字节的随机数(8位/字节),返回16进制转为10进制整数返回'''
randomdata = urandom(n)
return int(binascii.hexlify(randomdata),16)
#===========================================
def primality_testing_1(n):
'''测试一,小素数测试,用100以内的小素数检测随机数x,
可以很大概率排除不是素数,#创建有25个素数的元组'''
Sushubiao=(2,3,5,7,11,13,17,19,23,29,31,37,41
,43,47,53,59,61,67,71,73,79,83,89,97)
for y in Sushubiao:
if n%y==0:
return False
return True
#===========================================
def primality_testing_2(n, k):
'''测试二,用miller_rabin算法对n进行k次检测'''
if n < 2:
return False
d = n - 1
r = 0
while not (d & 1):
r += 1
d >>= 1
for _ in range(k):
a = randint(120) #随机数
x = pow(a, d, n)
if x == 1 or x == n - 1:
continue
for _ in range(r - 1):
x = pow(x, 2, n)
if x == 1:
return False
if x == n - 1:
break
else:
return False
return True
#===========================================
def getprime(byte):
while True :
n=randint(byte)
if primality_testing_1(n) :
if primality_testing_2(n, 10) :
pass
else :continue
else : continue
return n
#===========================================
def RSA():
p=getprime(128) #1024bit的大整数
q=getprime(128)
while p==q: #避免p/q值相同
q=getprime(128)
n=p*q #n值公开
OrLa=(p-1)*(q-1) #欧拉函数
e=524289
'''e的选择:e的二进制表示中应当含有尽量少量的1.
e取e=524289时,其二进制为10000000000000000001,
只有两个1,加密速度快且数字大'''
d=Mod_1(e,OrLa)
print('公钥为({0},{1});\n私钥为({2},{3})'.format(n,e,n,d))
message=input('请输入任意需要加密的内容:')
#从标准输入输出流接收数据,数字化再加解密
message=list(map(ord,message))
print('ciphertext数字化:',message)
ciphertext=[]
for x in message:
ciphertext.append(pow(x,e,n))
print('ciphertext加密:',ciphertext)
message=[]
while True :
message.append(int(input('输入密文组\n(需要结束时输入0):')))
if message[-1]==0:
del message[-1]
break
plaintext=[]
for x in message:
plaintext.append(pow(x,d,n))
print('plaintext解密:',plaintext)
plaintext=list(map(chr,plaintext))
print('plaintext字符化:',plaintext)
print('plaintext=',reduce((lambda x,y: x+y),plaintext))
#=================================================== RSA()
miller_rabin算法检测生成大素数的RSA算法实现的更多相关文章
- Miller_Rabbin算法判断大素数,Pollard_rho算法进行质因素分解
Miller-rabin算法是一个用来快速判断一个正整数是否为素数的算法.它利用了费马小定理,即:如果p是质数,且a,p互质,那么a^(p-1) mod p恒等于1.也就是对于所有小于p的正整数a来说 ...
- 计蒜客 Goldbach Miller_Rabin判别法(大素数判别法)
题目链接:https://nanti.jisuanke.com/t/25985 题目: Description: Goldbach's conjecture is one of the oldest ...
- 数学--数论--Miller_Rabin判断一个大数是不是素数(随机算法)
前提知识 1,费马定理:ap−1=1(mod p)a^{p-1}=1(mod\ p)ap−1=1(mod p)
- 重复造轮子之RSA算法(一) 大素数生成
出于无聊, 打算从头实现一遍RSA算法 第一步, 大素数生成 Java的BigInteger里, 有个现成的方法 public static BigInteger probablePrime(int ...
- RSA算法
RSA.h #ifndef _RSA_H #define _RSA_H #include<stdio.h> #include<iostream> #include<mat ...
- 基于私钥加密公钥解密的RSA算法C#实现
RSA算法是第一个能同时用于加密和数字签名的算法,也易于理解和操作. RSA是被研究得最广泛的公钥算法,从提出到现在已近二十年,经历了各种攻击的考验,逐渐为人们接受,普遍认为是目前最优秀的公钥方案之一 ...
- RSA算法原理与加密解密 求私钥等价求求模反元素 等价于分解出2个质数 (r*X+1)%[(p-1)(q-1)]=0
Rsapaper.pdf http://people.csail.mit.edu/rivest/Rsapaper.pdf [概述Abstract 1.将字符串按照双方约定的规则转化为小于n的正整数m, ...
- RSA算法java实现(BigInteger类的各种应用)
一.RSA算法 1.密钥生成 随机生成两个大素数p.q 计算n=p*q 计算n的欧拉函数f=(p-1)*(q-1) 选取1<e<f,使e与f互素 计算d,ed=1modf 公钥为(e,n) ...
- [转]应用RSACryptoServiceProvider类轻松实现RSA算法
在我们现实当中经常会存在需要对某些数据进行加密保护 然后进行解密的操作,比方,我们需要对某些XML配置信息里面的某些数据进行加密,以防止任何人打开该XML配置信息都能正常的看到该配置信息里面的内容,从 ...
随机推荐
- Linux MTD子系统 _从模型分析到Flash驱动模板
MTD(Memory Technology Device)即常说的Flash等使用存储芯片的存储设备,MTD子系统对应的是块设备驱动框架中的设备驱动层,可以说,MTD就是针对Flash设备设计的标准化 ...
- bootstrap-typeahead自动补充
官方文档:https://github.com/bassjobsen/Bootstrap-3-Typeahead 这个是基于bootstrap的typeahead与基于jquery的jquery-Ty ...
- Android Studio项目构建常见问题解决
1. 创建或导入项目后编译时一直在等待 问题: 原因:AS连网去下载gradle了,但是网络不好或不通 解决:禁用网络,AS就会立即自动终止下载进入到主界面了.此时再去指定离线的gradle版本进行编 ...
- 函数调用过程&生成器解释
摘自马哥解答,感谢. 函数调用过程: 假设程序是单进程,单执行流,在某一时刻,能运行的程序流只能有一个.但函数调用会打开新的执行上下文,因此,为了确保main函数可以恢复现场,在main函数调用其它函 ...
- shiro使用教程
一.shiro是什么 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码学和会话管理.不仅可以在Web项目中使用,在普通的项目中也是可以使用的 二.shiro可以做什 ...
- 老李分享:loadrunner 的86401错误
老李分享:loadrunner 的86401错误 系统和软件配置: os:windows 2003loadruner版本:LoadRunner11loadrunner:协议:SMTP协议并发数:2 ...
- 老李推荐:第6章1节《MonkeyRunner源码剖析》Monkey原理分析-事件源-事件源概览 2
事件要到那里去? 每个事件源处理类都维护着一个自己的事件队列, 在Monkey中叫做CommandQueue,里面装的是每个具体的MonkeyEvent事件.当来自网络的字串命令被翻译成对应的Monk ...
- QTP自动化测试培训:描述编程之WebElement
QTP自动化测试培训:描述编程之WebElement 通过描述性编程技术,来描述出来输入框: set po=browser("creationtime:=0").page(&q ...
- ngrok把本地主机映射到公网域名
这两天又要搞微信项目,然后我下载了一个QQ浏览器,搜索微信调试工具,我再搜,再搜,搜不出来,问了下客服,暂时下架了,好吧! 我上网搜了一下,就找到了 ngrok 这个东西,它也可以把你本地主机映射到 ...
- 用C#写经理评分系统
先写需求: 01.显示员工信息 02.实现项目经理给员工评分的功能 第一步: 建立两个类,员工类和项目经理类 定义属性和方法 员工类:工号.年龄.姓名.人气值.项 ...