Python rsa加密解密/签名验签,aes加密解密

#!/usr/bin/env python
# -*- coding:utf-8 -*-
import base64
from Crypto import Random
from Crypto.Hash import MD5  # or use SHA
from Crypto.Cipher import AES
from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_v1_5
from Crypto.Signature import PKCS1_v1_5 as Sign_PKCS1_v1_5


def create_pems():
    rsa = RSA.generate(1024, Random.new().read)
    private_pem = rsa.exportKey()
    public_pem = rsa.publickey().exportKey()
    return public_pem, private_pem


def rsa_encrypt(message):
    cipher = PKCS1_v1_5.new(RSA.importKey(public_pem))
    return base64.b64encode(cipher.encrypt(message.encode('utf-8'))).decode('utf-8')


def rsa_decrypt(cipher_text):
    cipher = PKCS1_v1_5.new(RSA.importKey(private_pem))
    return cipher.decrypt(base64.b64decode(cipher_text), Random.new().read).decode('utf-8')


def sign(message):
    cipher = Sign_PKCS1_v1_5.new(RSA.importKey(private_pem))
    return base64.b64encode(cipher.sign(MD5.new(data=message)))


def verify(message, cipher_text):
    cipher = Sign_PKCS1_v1_5.new(RSA.importKey(public_pem))
    return cipher.verify(MD5.new(message), base64.b64decode(cipher_text))


def aes_encrypt(password):
    cipher = AES.new(key, AES.MODE_CBC, iv)
    pad_length = 16 - len(password.encode()) % 16
    pad_string = pad_length * chr(pad_length)
    return base64.b64encode(cipher.encrypt('%s%s' % (password, pad_string))).decode()


def aes_decrypt(password):
    cipher = AES.new(key, AES.MODE_CBC, iv)
    password = cipher.decrypt(base64.b64decode(password))
    return password.decode().strip('')


public_pem, private_pem = create_pems()
message = "hello client, this is a message"

cipher_text = rsa_encrypt(message)
message = rsa_decrypt(cipher_text)
print(public_pem)
print(private_pem)
print('==========================aes encrypt=========================')
print(cipher_text)
print(message)

cipher_text = sign(message)
message = verify(message, cipher_text)
print('==========================aes sign============================')
print(cipher_text)
print(message)

key, iv = '<cq:"s|fd.t;\'ag\\', 'z!b#t%h&*v_u{n"J'
cipher_text = aes_encrypt('123456789')
print('==========================des encrypt=========================')
print(cipher_text)
print(aes_decrypt(cipher_text))

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值