Python RSA 签名、验证、加密、解密

1,919次阅读

共计 3541 个字符,预计需要花费 9 分钟才能阅读完成。

1 RSA密钥格式

常用的rsa密钥有两种格式,pkcs1pkcs8

1.1 pkcs1

# 公钥
-----BEGIN RSA PUBLIC KEY-----
-----END RSA PUBLIC KEY-----
# 私钥
-----BEGIN RSA PRIVATE KEY-----
-----END RSA PRIVATE KEY-----

1.2 pkcs8

# 公钥
-----BEGIN PUBLIC KEY-----
-----END PUBLIC KEY-----
# 私钥
-----BEGIN PRIVATE KEY-----
-----END PRIVATE KEY-----

2 密钥格式转换

2.1 私钥转换

pkcs1 to pkcs8

openssl pkcs8 -topk8 -inform PEM -in private_pkcs1.pem -outform pem -nocrypt -out private_pkcs8.pem

pkcs8 to pkcs1

openssl pkcs8 -in private_pkcs8.pem -nocrypt -out private_plcs1.pem

2.2 公钥转换

使用pkcs8格式私钥生成pkcs8格式公钥

openssl rsa -in pricate_pkcs8.pem -pubout -out public_pkcs8.pem

3 签名、验证、加密、解密

# -*- coding: utf-8 -*-
# Created: 03/03/2021
# Author: Wangxiao
​
import base64
import Crypto.Signature.PKCS1_v1_5 as sign_PKCS1_v1_5 #用于签名/验签
from Crypto.Cipher import PKCS1_v1_5 as Cipher_pkcs1_v1_5 #用于加密
from Crypto import Hash
from Crypto.PublicKey import RSA
​
​
class RsaCode(object):
    def __init__(self):
        self.public_key = "-----BEGIN PUBLIC KEY-----\nMGcw\n-----END PUBLIC KEY-----"
        self.private_key = "-----BEGIN PRIVATE KEY-----\nMIIBhQIBADANBgkqhkiG9w0BAQEFAAS\n-----END PRIVATE KEY-----"
​
    def sign(self, text):
        """
        私钥签名
        :return:
        """
        signer_pri_obj = sign_PKCS1_v1_5.new(RSA.importKey(self.private_key))
        rand_hash = Hash.MD5.new()
        rand_hash.update(text.encode())
        signature = signer_pri_obj.sign(rand_hash)
        return base64.b64encode(signature).decode(encoding="utf-8")
​
    def verify(self, text, sign_result):
        """
        RSA验签
        :param signature: 签名
        :return:
        """
        signature = base64.b64decode(sign_result)
        verifier = sign_PKCS1_v1_5.new(RSA.importKey(self.public_key))
        _rand_hash = Hash.MD5.new()
        _rand_hash.update(text.encode())
        verify = verifier.verify(_rand_hash, signature)
        return verify
​
​
    def long_encrypt(self, msg):
        msg = msg.encode('utf-8')
        length = len(msg)
        default_length = 64
        pubobj = Cipher_pkcs1_v1_5.new(RSA.importKey(self.public_key))
        if length < default_length:
            return base64.b64encode(pubobj.encrypt(msg)).decode(encoding="utf-8")
        offset = 0
        res = []
        while length - offset > 0:
            if length - offset > default_length:
                res.append(pubobj.encrypt(msg[offset:offset + default_length]))
            else:
                res.append(pubobj.encrypt(msg[offset:]))
            offset += default_length
        byte_data = b''.join(res)
        return base64.b64encode(byte_data).decode(encoding="utf-8")
​
    def long_decrypt(self, msg):
        msg = base64.b64decode(msg)
        length = len(msg)
        default_length = 75
        priobj = Cipher_pkcs1_v1_5.new(RSA.importKey(self.private_key))
        if length <= default_length:
            return priobj.decrypt(msg, b'RSA').decode(encoding="utf-8")
        offset = 0
        res = []
        while length - offset > 0:
            if length - offset > default_length:
                res.append(priobj.decrypt(msg[offset:offset + default_length], b'RSA'))
            else:
                res.append(priobj.decrypt(msg[offset:], b'RSA'))
            offset += default_length
        print()
        return b''.join(res).decode('utf-8')
​
​
if __name__ == '__main__':
    text = "python rsa test"
    print("1 开始签名")
    sign_result = RsaCode().sign(text)
    print("- 签名结果为: {}".format(sign_result))
    print("2 验证签名")
    verify_result = RsaCode().verify(text, sign_result)
    print("- 验证结果为: {}".format(verify_result))
​
    params = '{ "username": "python rsa" }'
    print("3 开始RSA加密")
    en_result = RsaCode().long_encrypt(params)
    print("- 加密结果为: {}".format(en_result))
    print("4 开始RSA解密")
    de_result = RsaCode().long_decrypt(en_result)
    print("- 解密结果为: {}".format(de_result))

4 验证结果

1 开始签名
- 签名结果为: QE+DF/YLbU/F6ARxeLGa3oJyiV2UvSxkxWuJJ8fruoKszc/v1+/Tl/4n5iHTb2q+/ODoqkvJOU2TYwjhp2AI9uOwyEkPUDai5mYc
2 验证签名
- 验证结果为: True
3 开始RSA加密
- 加密结果为: EkaF5LsLEmpgVrfEjSB4XfMf06mE/0XQzWChVD6wrYh6k0axaWejiry6jVX+TT+T7P4Aw4VjJ2i5pnG2Xpga+xodRtFTC+LTnAuU
4 开始RSA解密
- 解密结果为: { "username": "python rsa" }

 

正文完
 4
mervinwang
版权声明:本站原创文章,由 mervinwang 2021-03-03发表,共计3541字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
文章搜索