非对称密码算法RSA

RSA命名由来:

该篇笔记是结合多位大佬的博客总结的!

  • 1977年,三位数学家Rivest、Shamir 和 Adleman提出RSA(以三人名字命名)算法实现非对称加密。从那时直到现在,RSA算法一直是最广为使用的"非对称加密算法"。
  • RSA的安全性是建立在大整数因子分解的困难性上
  • 毫不夸张地说,只要有计算机网络的地方,就有RSA算法。但是一般不能直接用RSA进行加密,这是不安全的。在用RSA进行加密之前要对明文进行随机化填充(一般来说),因为对于相同的明文始终会给出相同的密文。
  • 公钥(n,e) 只能加密小于n的整数m,那么如果要加密大于n的整数,该怎么办?有两种解决方法:一种是把长信息分割成若干段短消息,每段分别加密;另一种是先选择一种"对称性加密算法"(比如DES),用这种算法的密钥加密信息,再用RSA公钥加密DES密钥
  • n的长度就是密钥长度。3233写成二进制是110010100001,一共有12位,所以这个密钥就是12位。实际应用中,RSA密钥一般是1024位,重要场合则为2048位。
  • 只要密钥长度足够长,用RSA加密的信息实际上是不能被解破的。

RAS算法:

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

实例:
在这里插入图片描述

代码展示:

def gcd(a, b): #求最大公因子
  if b == 0:
    return a
  else:
    return gcd(b, a % b)


def ext_gcd(a, b):  #求逆元,即a*i(mod)b==1;
  if
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,下面是模拟实现非对称密码算法RSA的加密解密功能的代码,代码中使用了Python语言实现: ```python import random def gcd(a, b): while b != 0: a, b = b, a % b return a def extended_gcd(a, b): if a == 0: return (b, 0, 1) else: g, y, x = extended_gcd(b % a, a) return (g, x - (b // a) * y, y) def modinv(a, m): g, x, y = extended_gcd(a, m) if g != 1: raise Exception('No modular inverse') else: return x % m def is_prime(num): if num < 2: return False for i in range(2, int(num**0.5)+1): if num % i == 0: return False return True def generate_keypair(p, q): if not (is_prime(p) and is_prime(q)): raise ValueError('Both numbers must be prime.') elif p == q: raise ValueError('p and q cannot be equal') n = p * q phi = (p-1) * (q-1) e = random.randrange(1, phi) g = gcd(e, phi) while g != 1: e = random.randrange(1, phi) g = gcd(e, phi) d = modinv(e, phi) return ((e, n), (d, n)) def encrypt(pk, plaintext): key, n = pk cipher = [(ord(char) ** key) % n for char in plaintext] return cipher def decrypt(pk, ciphertext): key, n = pk plain = [chr((char ** key) % n) for char in ciphertext] return ''.join(plain) if __name__ == '__main__': p = int(input("Enter a prime number (17, 19, 23, etc): ")) q = int(input("Enter another prime number (Not one you entered above): ")) public, private = generate_keypair(p, q) print("Your public key is ", public, " and your private key is ", private) message = input("Enter a message to encrypt with your private key: ") encrypted_msg = encrypt(private, message) print("Your encrypted message is: ") print(''.join(map(lambda x: str(x), encrypted_msg))) print("Decrypting message with public key ", public, " . . .") print("Your message is:") print(decrypt(public, encrypted_msg)) ``` 使用方法: 1. 首先输入两个不同的质数 p 和 q; 2. 程序会自动生成公钥和私钥,分别保存在 public 和 private 变量中; 3. 输入要加密的信息 message; 4. 程序会用私钥加密信息,并输出加密后的密文 encrypted_msg; 5. 程序会用公钥解密密文,并输出解密后的明文 message。 需要注意的是,这里生成的密文是数字序列,需要转换成字符序列,才能正确地输出解密后的明文。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值