Rabin加密算法

描述

  Rabin加密算法和RSA加密算法形式类似,但解密过程有所不同。Rabin加密算法的解密过程会得到4个不同的明文,具体明文是哪一个还需要通过验证码进行验证。

加密

  由于Rabin加密算法是RSA加密算法的衍生类,因此有:令 N = p q N=pq N=pq,其中 p 、 q p、q pq均为较大的奇素数;对于任意明文 m m m,有对应的密文 c c c,加密过程如下:
c ≡ m 2   ( m o d   N ) c\equiv m^2\ (mod\ N) cm2 (mod N)

解密

情况1: p ≡ q ≡ 3   ( m o d   4 ) p\equiv q\equiv 3\ (mod\ 4) pq3 (mod 4)
  • 由于 m 2 ≡ c   ( m o d   p ) m^2\equiv c\ (mod\ p) m2c (mod p),因此根据模平方剩余和欧拉判别法有:
    c p − 1 2 ≡ 1   ( m o d   p ) c^{\frac{p-1}{2}}\equiv 1\ (mod\ p) c2p11 (mod p)又因为: c ≡ m 2   ( m o d   N ) c\equiv m^2\ (mod\ N) cm2 (mod N)因此有: m p 2 ≡ c ≡ c ∗ 1 ≡ c ∗ c p − 1 2 ≡ c p + 1 2 ≡ ( c p + 1 4 ) 2   ( m o d   p ) m q 2 ≡ c ≡ c ∗ 1 ≡ c ∗ c q − 1 2 ≡ c q + 1 2 ≡ ( c q + 1 4 ) 2   ( m o d   q ) m_p^2\equiv c\equiv c*1\equiv c*c^{\frac{p-1}{2}}\equiv c^{\frac{p+1}{2}}\equiv (c^{\frac{p+1}{4}})^2\ (mod\ p)\\ m_q^2\equiv c\equiv c*1\equiv c*c^{\frac{q-1}{2}}\equiv c^{\frac{q+1}{2}}\equiv (c^{\frac{q+1}{4}})^2\ (mod\ q) mp2cc1cc2p1c2p+1(c4p+1)2 (mod p)mq2cc1cc2q1c2q+1(c4q+1)2 (mod q)即:
    m p ≡ c p + 1 4   ( m o d   p ) m q ≡ c q + 1 4   ( m o d   q ) m_p\equiv c^{\frac{p+1}{4}}\ (mod\ p)\\ m_q\equiv c^{\frac{q+1}{4}}\ (mod\ q) mpc4p+1 (mod p)mqc4q+1 (mod q)
  • 再由扩展欧几里得方法计算出 y p y_p yp y q y_q yq
    y p ∗ p + y q ∗ q = 1 y_p*p+y_q*q=1 ypp+yqq=1
  • 计算出四个明文:
    m 1 ≡ y p ∗ p ∗ m q + y q ∗ q ∗ m p   ( m o d   N ) m 2 ≡ N − m 1 m 3 ≡ y p ∗ p ∗ m q − y q ∗ q ∗ m p   ( m o d   N ) m 4 ≡ N − m 3 m_1\equiv y_p*p*m_q+y_q*q*m_p\ (mod\ N)\\ m_2\equiv N-m_1\\ m_3\equiv y_p*p*m_q-y_q*q*m_p\ (mod\ N)\\ m_4\equiv N-m_3 m1yppmq+yqqmp (mod N)m2Nm1m3yppmqyqqmp (mod N)m4Nm3

下证明文的正确性:
m 1 2 ≡ ( y p ∗ p ∗ m q + y q ∗ q ∗ m ) 2 ≡ ( y p ∗ p ∗ m q ) 2 + ( y q ∗ q ∗ m ) 2   ( m o d   N ) ∵ m p 2 ≡ k p ∗ p + c ,   m q 2 ≡ k q ∗ q + c ∴ m 1 2 ≡ y p 2 ∗ p 2 ∗ ( k p ∗ p + c ) + y q 2 ∗ q 2 ∗ ( k q ∗ q + c ) ≡ c ( y p 2 ∗ p 2 + y q 2 ∗ q 2 )   ( m o d   N ) 又 ∵ y p ∗ p + y q ∗ q = 1 ∴ m 1 2 ≡ c ( ( y p ∗ p + y q ∗ q ) 2 − 2 ∗ y p ∗ p ∗ y q ∗ q ) ≡ c   ( m o d   N ) m_1^2\equiv (y_p*p*m_q+y_q*q*m)^2\equiv (y_p*p*m_q)^2+(y_q*q*m)^2\ (mod\ N)\\ ∵m_p^2\equiv k_p*p+c,\ m_q^2\equiv k_q*q+c\\ ∴m_1^2\equiv y_p^2*p^2*(k_p*p+c)+y_q^2*q^2*(k_q*q+c)\equiv c(y_p^2*p^2+y_q^2*q^2)\ (mod\ N)\\ 又∵y_p*p+y_q*q=1\\ ∴m_1^2\equiv c((y_p*p+y_q*q)^2-2*y_p*p*y_q*q)\equiv c\ (mod\ N) m12(yppmq+yqqm)2(yppmq)2+(yqqm)2 (mod N)mp2kpp+c, mq2kqq+cm12yp2p2(kpp+c)+yq2q2(kqq+c)c(yp2p2+yq2q2) (mod N)ypp+yqq=1m12c((ypp+yqq)22yppyqq)c (mod N)其他明文的证明方式同理。

情况2: p 、 q p、q pq非特殊值
  • ∵ m 2 ≡ c   ( m o d   N ) ∴ m p ≡ c   ( m o d   p ) 且 m q ≡ c   ( m o d   q ) ∵m^2\equiv c\ (mod\ N)\\ ∴m_p\equiv \sqrt c\ (mod\ p)且m_q\equiv \sqrt c\ (mod\ q) m2c (mod N)mpc  (mod p)mqc  (mod q)此为求解模平方根过程Cipolla算法
  • 其余值计算方式与情况1一致,只需替换掉 m p 、 m q m_p、m_q mpmq的计算过程即可。

参考资料

[1]. Rabin加密算法和n次同余方程
[2]. RSA 衍生算法——Rabin 算法
[3]. Rabin加密算法

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Rabin加密算法是一种非对称加密算法,它是基于大数分解难题的加密算法,其加密过程与RSA算法类似,但解密过程却与RSA不同,需要通过求解模数的因子来实现解密。以下是Rabin加密算法的实现步骤: 1. 选择两个大质数p和q,并计算模数N=p*q。 2. 将明文转化为数字M,使得M小于模数N。 3. 将M的平方对模数N取余,得到C=M^2 mod N,即为密文。 4. 使用数学方法求解模数N的两个因子p和q,然后就可以得到明文M。 解密过程相对于RSA算法更加困难,因为需要通过大数分解来求解模数的两个因子p和q。这也是Rabin加密算法的缺点之一。 以下是一个简单的Python实现Rabin加密算法的代码: ``` import random # 生成大质数 def generate_prime(): while True: p = random.randint(100000, 999999) if is_prime(p): return p # 判断是否为质数 def is_prime(n): if n <= 1: return False for i in range(2, int(n ** 0.5) + 1): if n % i == 0: return False return True # 计算最大公约数 def gcd(a, b): while b != 0: a, b = b, a % b return a # 求解模数的两个因子 def factorize(N): x = int(N ** 0.5) y = x r = 1 while r != 0: x = (x + y) % N y = (y ** 2 + r) % N r = (r + 1) % N d = gcd(abs(x - y), N) if d != 1 and d != N: return d, N // d # 加密函数 def encrypt(M): p = generate_prime() q = generate_prime() N = p * q C = (M ** 2) % N return C, N # 解密函数 def decrypt(C, N): p, q = factorize(N) mp = pow(C, (p + 1) // 4, p) mq = pow(C, (q + 1) // 4, q) yq, xp = gcd(p, q) x1 = (yq * p * mq + xp * q * mp) % N x2 = N - x1 return x1, x2 # 测试 M = 1234567890 C, N = encrypt(M) print("加密后的密文:", C) M1, M2 = decrypt(C, N) print("解密后的明文:", M1) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

D-A-X

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值