加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

Python实现的rsa加密算法详解

发布时间:2020-12-17 07:30:49 所属栏目:Python 来源:网络整理
导读:本篇章节讲解Python实现的rsa加密算法。供大家参考研究具体如下: 算法过程 1. 随意选择两个大的质数p和q,p不等于q,计算N=pq。 2. 根据欧拉函数,不大于N且与N互质的整数数(p-1)(q-1)。 3. 选择一个整数e与(p-1)(q-1)互质,并且e小于(p-1)(q-1)

本篇章节讲解Python实现的rsa加密算法。分享给大家供大家参考,具体如下:

算法过程

1. 随意选择两个大的质数p和q,p不等于q,计算N=pq。
2. 根据欧拉函数,不大于N且与N互质的整数数(p-1)(q-1)。
3. 选择一个整数e与(p-1)(q-1)互质,并且e小于(p-1)(q-1)。
4. 用以下这个公式计算d:d× e ≡ 1 (mod (p-1)(q-1))。
5. 将p和q的记录销毁。

(N,e)是公钥,(N,d)是私钥。

python代码

# -*- coding: utf-8 -*-
#!/usr/bin/env python
def range_prime(start,end):
 l = list()
 for i in range(start,end+1):
  flag = True
  for j in range(2,i):
   if i % j == 0:
    flag = False
    break
  if flag:
   l.append(i)
 return l
def generate_keys(p,q):
 #numbers = (11,13,17,19,23,29,31,37,41,43,47)
 numbers =range_prime(10,100)
 N = p * q
 C = (p-1) * (q-1)
 e = 0
 for n in numbers:
  if n < C and C % n > 0:
   e = n
   break
 if e==0:
  raise StandardError("e not found") #Python3中改为BaseException
 d = 0
 for n in range(2,C):
  if(e * n) % C == 1:
   d = n
   break
 if d==0:
  raise StandardError("d not found")
 return ((N,e),(N,d))
def encrypt(m,key):
 C,x = key
 return (m ** x) % C
decrypt = encrypt
if __name__ == '__main__':
 pub,pri = generate_keys(47,79)
 L = range(20,30)
 C = map(lambda x: encrypt(x,pub),L)
 D = map(lambda x: decrypt(x,pri),C)
 print "编程小技巧测试结果:"
 print "keys:",pub,pri
 print "message:",L
 print "encrypt:",C
 print "decrypt:",D

运行结果:

其实用什么语言实现这个过程都不是很麻烦,只是我们老师要求生成1024的随机数,用c语言写就有点恶心了,所以用python或者java实现要更加方便一点。

PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:

文字在线加密解密工具(包含AES、DES、RC4等):
http://tools.aspzz.cn/password/txt_encode

MD5在线加密工具:
http://tools.aspzz.cn/password/CreateMD5Password

在线散列/哈希算法加密工具:
http://tools.aspzz.cn/password/hash_encrypt

在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.aspzz.cn/password/hash_md5_sha

在线sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.aspzz.cn/password/sha_encode

更多关于Python相关内容感兴趣的读者可查看本站专题:《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python数据结构与算法教程》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

您可能感兴趣的文章:

  • python使用rsa加密算法模块模拟新浪微博登录
  • Python使用Pycrypto库进行RSA加密的方法详解
  • python实现RSA加密(解密)算法
  • python rsa 加密解密
  • Python下实现的RSA加密/解密及签名/验证功能示例
  • python实现rsa加密实例详解
  • python利用rsa库做公钥解密的方法教程
  • Python基于DES算法加密解密实例
  • python实现的DES加密算法和3DES加密算法实例
  • Python md5与sha1加密算法用法分析
  • Python实现的文本简单可逆加密算法示例

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读