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
  • asp之家 网络编程 m.aspxhome.com