Python与JavaScript关于AES加解密和RSA加解密

Python与JavaScript关于AES加解密和RSA加解密

在线生成公钥私钥对,RSA公私钥生成
AESjs文件
RSAjs文件
JSEncrypt文件

JavaScript

function generateRandomString(length) {
	let charset = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789!\"#$%&'()*+,-./:;<=>?@[]^_`{|}~";
	let values = new Uint32Array(length);
	window.crypto.getRandomValues(values);
	let str = '';
	for (let i = 0; i < length; i++) {
		str += charset[values[i] % charset.length];
	}
	return str;
}
function AESEncrypt(data, key) {
	key = CryptoJS.enc.Utf8.parse(key)
	data = CryptoJS.enc.Utf8.parse(data)
	const encrypted = CryptoJS.AES.encrypt(data, key, {
		iv: key,
		mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
	});
	return CryptoJS.enc.Base64.stringify(encrypted.ciphertext);
}
function AESDecrypt(data, key) {
	key = CryptoJS.enc.Utf8.parse(key)
    data = CryptoJS.enc.Base64.parse(data)
    data = CryptoJS.enc.Base64.stringify(data)
	const decrypted = CryptoJS.AES.decrypt(data, key, {
		iv: key,
		mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
	});
	return CryptoJS.enc.Utf8.stringify(decrypted).toString();
}
function RSAEncrypt(data, key) {
	key = key.replace("-----BEGIN PUBLIC KEY-----", "");
	key = key.replace("-----END PUBLIC KEY-----", "");
	key = key.replace(/\n/g, "");
	key = key.trim();
	const encrypt = new JSEncrypt();
	encrypt.setPublicKey(key);
	return encrypt.encrypt(data);
}
function RSADecrypt(data, key) {
	key = key.replace("-----BEGIN PRIVATE KEY-----", "");
	key = key.replace("-----END PRIVATE KEY-----", "");
	key = key.replace(/\n/g, "");
	key = key.trim();
	const decrypt = new JSEncrypt();
	decrypt.setPrivateKey(key);
	return decrypt.decrypt(data);
}
function RSASign(data, key) {
	const sign = new JSEncrypt();
	sign.setPrivateKey(key);
	return sign.sign(data, CryptoJS.SHA256, "sha256");
}
function RSAVerify(data, signature, key) {
	const verify = new JSEncrypt();
	verify.setPublicKey(key);
	return verify.verify(data, signature, CryptoJS.SHA256);
}

Python

import base64
import random
import string

from Crypto.Cipher import AES, PKCS1_v1_5 as Cipher_pkcs1_v1_5
from Crypto.Hash import SHA256
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5


def generate_random_str(random_length=16, digits_str=True, ascii_str=True, punctuation_str=False):
    """
    生成一个指定长度的随机字符串,其中
    string.digits=0123456789
    string.ascii_letters=abcdefghigklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ
    string.punctuation=!"#$%&'()*+,-./:;<=>?@[]^_`{|}~
    :param random_length: 生成的字符串长度,默认16位
    :param digits_str: 是否存在数字
    :param ascii_str: 是否存在大小写字母
    :param punctuation_str: 是否存在标点符号
    :return: 一串字符串
    """
    char = ''
    if digits_str:
        char += string.digits
    if ascii_str:
        char += string.ascii_letters
    if punctuation_str:
        char += string.punctuation
    str_list = [random.choice(char) for _ in range(random_length)]
    random_str = ''.join(str_list)
    return random_str


RSA_PublicKey = """-----BEGIN PUBLIC KEY-----...-----END PUBLIC KEY-----"""
RSA_PrivateKey = """-----BEGIN PRIVATE KEY-----...-----END PRIVATE KEY-----"""

class AESCipher:
    def __init__(self, key):
        self.key = key
        # 这里直接用key充当iv
        self.iv = key

	def encrypt(self, raw):
        """
        加密方法
        :param raw: 需要加密的密文 str
        :return: base64编码的密文 str
        """
        cipher = AES.new(self.key.encode('utf-8'), AES.MODE_CBC, self.iv.encode('utf-8'))
        return base64.b64encode(cipher.encrypt(self._pad(raw.encode()))).decode()

    def decrypt(self, enc):
        """
        解密方法
        :param enc: base64编码的密文 str
        :return: 解密后的明文 str
        """
        cipher = AES.new(self.key.encode('utf-8'), AES.MODE_CBC, self.iv.encode('utf-8'))
        return self._unpad(cipher.decrypt(base64.b64decode(enc))).decode()

    @staticmethod
    def _pad(s):
        return s + (16 - len(s) % 16) * chr(16 - len(s) % 16).encode()

    @staticmethod
    def _unpad(s):
        return s[0:-ord(s[len(s) - 1:])]


class RSACipher:
    """
    RSA加密、解密、签名、验签工具类
    """
    @staticmethod
    def encrypt(key, raw):
        """
        加密方法
        :param key: 公钥
        :param raw: 需要加密的明文 bytes
        :return: base64编码的密文 bytes
        """
        rsa_key = RSA.importKey(key)
        cipher = Cipher_pkcs1_v1_5.new(rsa_key)
        cipher_text = base64.b64encode(cipher.encrypt(raw.encode()))
        return cipher_text.decode()

    @staticmethod
    def decrypt(key, enc):
        """
        解密方法
        :param key: 私钥
        :param enc: base64编码的密文 bytes
        :return: 解密后的明文 bytes
        """
        decodeStr = base64.b64decode(enc)  # cipher_text是上面rsa加密的内容
        rsa_key = RSA.importKey(key)
        private_key = Cipher_pkcs1_v1_5.new(rsa_key)
        encry_text = private_key.decrypt(decodeStr, b'rsa')
        return encry_text.decode('utf8')

    @staticmethod
    def sign(key, text):
        """
        签名方法
        :param key: 私钥
        :param text: 需要签名的文本 bytes
        :return: base64编码的签名信息 bytes
        """
        private_key = RSA.importKey(key)
        hash_value = SHA256.new(text.encode())
        signer = PKCS1_v1_5.new(private_key)
        signature = signer.sign(hash_value)
        return base64.b64encode(signature).decode()

    @staticmethod
    def verify(key, text, signature):
        """
        验签方法
        :param key: 公钥
        :param text: 需要验签的文本 bytes
        :param signature: base64编码的签名信息 bytes
        :return: 验签结果 bool
        """
        public_key = RSA.importKey(key)
        hash_value = SHA256.new(text.encode())
        verifier = PKCS1_v1_5.new(public_key)
        return verifier.verify(hash_value, base64.b64decode(signature))

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值