Python3.7基于hashlib和Crypto实现加签验签功能(实例代码)
作者:clkai 时间:2023-03-25 16:23:00
环境:
Python3.7
依赖库:
import datetime
import random
import requests
import hashlib
import json
import base64
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5
from Crypto.Hash import SHA256
from Crypto.Cipher import AES
加签:
def sign(signflag,keypath,baseRequest):
#http请求body
print(baseRequest)
#加签标志
if not signflag: return baseRequest
else:
#取请求体中的业务数据
businessdata = json.dumps(baseRequest["data"])
#读取私钥(.key格式,可使用openssl或java.keytools产生)
with open(keypath,'r') as rsaKeyFile:
rsaKey = rsaKeyFile.read().replace("\n",'')
print(rsaKey)
rsaKeyBytes = base64.b64decode(rsaKey)
print(rsaKeyBytes)
#SHA256摘要,RSA加密
priKey = RSA.importKey(rsaKeyBytes)
signer = PKCS1_v1_5.new(priKey)
hash_obj = SHA256.new(business_data.encode('utf-8'))
signature = base64.b64encode(signer.sign(hash_obj))
print(signature)
#把签名加进请求体并返回
baseRequest['sign'] = signature.decode()
print(baseRequest)
return baseRequest
验签:
def validata(signflag,cerpath,res):
if not signflag: return res
else:
#取业务数据和签名
data = res['data']
sign = res['sign']
#此处cer已转换成pem格式,使用openssl工具
#openssl x509 -inform der -pubkey -noout -in xxxxx.cer>xxxxx.pem
cert = open(cerpath).read().replace("-----BEGIN PUBLIC KEY-----\n","").replace("-----END PUBLIC KEY-----\n","").replace("\n","")
print(cert)
#验签逻辑同加签
pubBytes = base64.b64decode(cert)
pubKey = RSA.importKey(pubBytes)
signer = SHA256.new(json.dumps(data).encode("utf-8"))
verifier = PKCS1_v1_5.new(pubKey)
return verifier.verify(signer,base64.b64decode(sign))
总结
以上所述是小编给大家介绍的Python3.7基于hashlib和Crypto实现加签验签功能网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
来源:https://blog.csdn.net/weixin_43886252/article/details/103344462
标签:python,hashlib,Crypto,加签,验签
0
投稿
猜你喜欢
python结合shell自动创建kafka的连接器实战教程
2023-01-06 19:17:13
一篇文章带你详细了解python中一些好用的库
2022-03-18 09:02:19
Ajax编程之旅第一站:HTTP请求
2008-08-07 12:55:00
Javascript"篱式"条件判断(翻译)
2008-08-01 12:21:00
pandas groupby 用法实例详解
2023-07-19 01:37:59
python图像和办公文档处理总结
2021-03-08 19:24:02
TypeScript类型检查详谈及火爆原因
2022-01-24 11:48:41
Python+Dlib+Opencv实现人脸采集并表情判别功能的代码
2022-02-26 00:53:49
Python面向对象总结及类与正则表达式详解
2021-08-12 13:23:34
如何利用Pytorch计算三角函数
2021-01-27 11:35:47
MySQL中Distinct和Group By语句的基本使用教程
2024-01-26 09:51:53
MySQL如何优化查询速度
2024-01-17 05:38:04
可以在线创建文件夹吗?
2009-11-01 18:07:00
python实现画桃心表白
2021-05-14 16:27:00
Python基于FTP模块实现ftp文件上传操作示例
2024-01-02 00:04:38
零基础学习python偏函数语法的推导方法步骤
2021-07-17 20:59:18
Mootools 1.2教程(10)——Fx.Tween的使用
2008-12-02 18:03:00
javascript div 遮罩层封锁整个页面
2024-06-09 01:20:09
Python Pandas高级教程之时间处理
2021-08-12 14:04:49
一文理解Goland协程调度器scheduler的实现
2024-05-22 17:44:53