PyOpenSSL数字签名

PyOpenSSL是一个封装了OpenSSLPython模块
源码仓库地址
GitHub

PyOpenSSL生成密钥对

  • PKey对象快速生成密钥对

    from OpenSSL.crypto import PKey, TYPE_RSA
    
    
    pk = PKey()
    pk.generate_key(type=TYPE_RSA, bits=1024)
    
    
  • dump_方法读取密钥对

    from OpenSSL.crypto import FILETYPE_PEM, dump_publickey, dump_privatekey
    
    
    public = dump_publickey(FILETYPE_PEM, pk)
    private = dump_privatekey(FILETYPE_PEM, pk)
    print(public.decode('utf-8'))
    print(private.decode('utf-8'))
    
    

数字签名原理

  • 签名过程

    签名过程
    Hash运算
    私钥加密
    信息摘要
    合约内容
    签名
    合约+签名
  • 验证过程

    验证过程
    Hash运算
    公钥解密
    信息摘要
    合约内容
    信息摘要
    签名
    是否一致
    合约+签名

PyOpenSSL实现数字签名

digest为生成信息摘要用到的Hash算法,这里用到了SHA-1算法

  • 签名过程

    from OpenSSL.crypto import PKey, TYPE_RSA, sign
    
    
    # 生成密钥对
    pk = PKey()
    pk.generate_key(type=TYPE_RSA, bits=1024)
    
    # 待签名内容
    message = str(input('输入签名内容: ')).encode('utf-8')
    
    # 数字签名,digest
    signature = sign(pkey=pk, data=message, digest='sha1')
    print(signature)
    
    
  • 验证过程

    如果签名内容与原文不符合,verify方法将报错

    from OpenSSL.crypto import verify, X509
    
    
    x509 = X509()
    x509.set_pubkey(pk)
    verify(x509, signature=signature, data=message, digest='sha1')
    
    
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值