zoukankan      html  css  js  c++  java
  • python生成RSA签名

    # -*- coding: utf-8 -*-
    # Auth :yuyu
    
    # pip install -i https://pypi.douban.com/simple/ pycryptodome
    from Crypto.Cipher import PKCS1_v1_5
    from Crypto.PublicKey import RSA
    import base64
    import os
    
    '''不分段'''
    def get_sgin(out_trade_no=None,type=None,price=None,pay_password=None,phone=None,public_data=None):
    
        if out_trade_no:
            msg = "out_trade_no={}&price={}&pay_password={}".format(out_trade_no, price, pay_password)
        else:
            msg = "type={}&info=2&phone={}&app_id=com.jiutongfuwu.wantcashier".format(type, phone)
        # 读取文件中的公钥
        key = open(public_data).read()  #文件的公钥
        publickey = RSA.importKey(key)
        # 进行加密
        pk = PKCS1_v1_5.new(publickey)
        encrypt_text = pk.encrypt(msg.encode())
        # 加密通过base64进行编码
        result = base64.b64encode(encrypt_text)
        result = str(result, encoding="utf-8")  # byte类型转换为str
        return result
    
    # if __name__ == '__main__':
    #     public_data ='public.pem'
    #     res =get_sgin(type=1,public_data =public_data)
    #     print(res)
    
    '''分段'''
    def join_sgin(data,public_data): # data 是参数
        key =open(public_data).read()
        publickey =RSA.importKey(key)
        #分段
        pk = PKCS1_v1_5.new(publickey)
        encrypt_text =[]
    
        for i in range(0,len(data),100):
            context = data[i,i+100]
            encrypt_text.append(pk.encrypt(context.encode()))
            cipher_text = b''.join(encrypt_text)
            #加密通过base64
            result = base64.b64encode(cipher_text)
            result =str(result,encoding= 'utf-8')
            return result
  • 相关阅读:
    js18
    js17
    js16
    js15
    js14
    js13
    js12
    js11
    八月二十三的php
    八月二十二的php
  • 原文地址:https://www.cnblogs.com/chevron123/p/14833869.html
Copyright © 2011-2022 走看看