python 实现RSA数字签名

复制代码
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5 as Cipher_pkcs1_v1_5
from Crypto.Signature import PKCS1_v1_5 as Signature_pkcs1_v1_5
import base64

# 私钥
private_key = '''-----BEGIN RSA PRIVATE KEY-----
5353dfggd
-----END RSA PRIVATE KEY-----
'''

# 公钥
public_key = '''-----BEGIN PUBLIC KEY-----
hfgghftetet
-----END PUBLIC KEY-----'''
def rsa_sign(plaintext, hash_algorithm=Crypto.Hash.MD5):
    """RSA 数字签名,私钥进行签名"""
    signer = Signature_pkcs1_v1_5.new(RSA.importKey(private_key))

    # hash算法必须要pycrypto库里的hash算法,不能直接用系统hashlib库,pycrypto是封装的hashlib
    hash_value = hash_algorithm.new(plaintext.encode('utf-8'))
    signature = signer.sign(hash_value)
    signature = base64.b64encode(signature)
    return signature.decode()


def rsa_verify(sign, plaintext, hash_algorithm=Crypto.Hash.MD5):
    """校验RSA 数字验签,公钥进行验签"""
    sign = base64.b64decode(sign)
    hash_value = hash_algorithm.new(plaintext.encode('utf-8'))
    verifier = Signature_pkcs1_v1_5.new(RSA.importKey(public_key))
    return verifier.verify(hash_value, sign)
复制代码

 

posted @   **绵绵羊**  阅读(2991)  评论(0编辑  收藏  举报
编辑推荐:
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~
点击右上角即可分享
微信分享提示