ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

python实现数字签名2

2021-12-30 00:00:45  阅读:184  来源: 互联网

标签:return 14 数字签名 算法 python 素数 实现 def mod


1、生成私公密钥对

from Crypto.PublicKey import RSA


def generate_key(bits):
    return RSA.generate(bits)


if __name__ == "__main__":
    key = generate_key(2048)

    # 生成私钥文件
    sk = key.export_key()
    with open('master-private.pem', 'wb') as f:
        f.write(sk)

    # 生成公钥文件
    pk = key.publickey().export_key()
    with open('master-public.pem', 'wb') as f:
        f.write(pk)

2、RSA密钥生成

  • 选择两个随机的大素数p和q,并计算n=pq和φ(n)=(p-1)(q-1);
  • 选择一个随机数e,1<e<φ(n),满足gcd(e,φ(n))=1,并计算ed ≡ 1 (mod φ(n));
    (gcd函数返回两个或多个整数的最大公约数;)
  • 此时得出,公钥为(e, n),私钥为d。
    这里关于e的选择,理论计算是产生一系列的随机数,检验每一个是否和φ(n)互素,直到找到了一个这样的数为止。在实践中,为了提高RSA的加密速度,通常用的三个e值为3、7和65537。X.509中建议采用65537,PEM建议采用3,PKCS#1中建议采用3或65537。

3、RSA加密

  • 加密公式为c≡ m^e(mod n),m明文需要满足0≤m<n的条件,所以在加密前要对明文比特串分组,然后对每一个分组进行加密,最后得到所有分组的密文,这些密文构成的序列即明文加密的结果。

4、RSA解密

  • 解密公式为m≡ c^d(mod n),每组的密文c要求同样需满足0≤c<n。
  • 这里选取小数据对上述的 RSA 算法进行说明:
    产生密钥:Alice 选取素数 p = 2357 和 q = 2551,计算 n = pq = 6012707,

    标签:return,14,数字签名,算法,python,素数,实现,def,mod
    来源: https://blog.csdn.net/weixin_43685341/article/details/122220433

    本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
    2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
    3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
    4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
    5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有