2025年3月25日 星期二 甲辰(龙)年 月廿四 设为首页 加入收藏
rss
您当前的位置:首页 > 计算机 > 编程开发 > Python

python 使用 rsa库进行RSA签名和加解密

时间:08-17来源:作者:点击数:31

python 使用 rsa库进行RSA签名和加解密

  • # -*- coding: UTF-8 -*-
  • # ! /usr/bin/env python
  • import base64
  • import rsa
  • from rsa import common
  • # 使用 rsa库进行RSA签名和加解密
  • class RsaUtil(object):
  • PUBLIC_KEY_PATH = '/tmp/gbzj/public_key.pem' # 公钥
  • PRIVATE_KEY_PATH = '/tmp/gbzj/private_key.pem' # 私钥
  • # 初始化key
  • def __init__(self,
  • company_pub_file=PUBLIC_KEY_PATH,
  • company_pri_file=PRIVATE_KEY_PATH):
  • if company_pub_file:
  • self.company_public_key = rsa.PublicKey.load_pkcs1_openssl_pem(open(company_pub_file).read())
  • if company_pri_file:
  • self.company_private_key = rsa.PrivateKey.load_pkcs1(open(company_pri_file).read())
  • def get_max_length(self, rsa_key, encrypt=True):
  • """加密内容过长时 需要分段加密 换算每一段的长度.
  • :param rsa_key: 钥匙.
  • :param encrypt: 是否是加密.
  • """
  • blocksize = common.byte_size(rsa_key.n)
  • reserve_size = 11 # 预留位为11
  • if not encrypt: # 解密时不需要考虑预留位
  • reserve_size = 0
  • maxlength = blocksize - reserve_size
  • return maxlength
  • # 加密 支付方公钥
  • def encrypt_by_public_key(self, message):
  • """使用公钥加密.
  • :param message: 需要加密的内容.
  • 加密之后需要对接过进行base64转码
  • """
  • encrypt_result = b''
  • max_length = self.get_max_length(self.company_public_key)
  • while message:
  • input = message[:max_length]
  • message = message[max_length:]
  • out = rsa.encrypt(input, self.company_public_key)
  • encrypt_result += out
  • encrypt_result = base64.b64encode(encrypt_result)
  • return encrypt_result
  • def decrypt_by_private_key(self, message):
  • """使用私钥解密.
  • :param message: 需要加密的内容.
  • 解密之后的内容直接是字符串,不需要在进行转义
  • """
  • decrypt_result = b""
  • max_length = self.get_max_length(self.company_private_key, False)
  • decrypt_message = base64.b64decode(message)
  • while decrypt_message:
  • input = decrypt_message[:max_length]
  • decrypt_message = decrypt_message[max_length:]
  • out = rsa.decrypt(input, self.company_private_key)
  • decrypt_result += out
  • return decrypt_result
  • # 签名 商户私钥 base64转码
  • def sign_by_private_key(self, data):
  • """私钥签名.
  • :param data: 需要签名的内容.
  • 使用SHA-1 方法进行签名(也可以使用MD5)
  • 签名之后,需要转义后输出
  • """
  • signature = rsa.sign(data, priv_key=self.company_private_key,
  • hash_method='SHA-256') # 加密方式Use 'MD5', 'SHA-1', 'SHA-224', SHA-256', 'SHA-384' or 'SHA-512'
  • return base64.b64encode(signature)
  • def verify_by_public_key(self, message, signature):
  • """公钥验签.
  • :param message: 验签的内容.
  • :param signature: 对验签内容签名的值(签名之后,会进行b64encode转码,所以验签前也需转码).
  • """
  • signature = base64.b64decode(signature)
  • return rsa.verify(message, signature, self.company_public_key)
  • message = 'appId=f334fdgd&bizContent={"authCode":"4196a49571e747259028fa25df330604b4f6d301"}&timestamp=2022-08-01 10:20:08'
  • print("明文内容:>>> ")
  • print(message)
  • rsaUtil = RsaUtil()
  • encrypy_result = rsaUtil.encrypt_by_public_key(message)
  • print("加密结果:>>> ")
  • print(encrypy_result)
  • decrypt_result = rsaUtil.decrypt_by_private_key(encrypy_result)
  • print("解密结果:>>> ")
  • print(decrypt_result)
  • sign = rsaUtil.sign_by_private_key(message)
  • print("签名结果:>>> ")
  • print(sign)
  • print("验签结果:>>> ")
  • print(rsaUtil.verify_by_public_key(message, sign))

 

方便获取更多学习、工作、生活信息请关注本站微信公众号城东书院 微信服务号城东书院 微信订阅号
推荐内容
相关内容
栏目更新
栏目热门
本栏推荐