mirror of
https://github.com/daiyanan1992/qinglongtest
synced 2025-12-17 23:34:47 +08:00
37 lines
1.3 KiB
Python
37 lines
1.3 KiB
Python
#!/usr/bin/python3
|
|
# -- coding: utf-8 --
|
|
# -------------------------------
|
|
# @Author : github@limoruirui https://github.com/limoruirui
|
|
# @Time : 2022/8/23 13:05
|
|
# -------------------------------
|
|
try:
|
|
from Crypto.PublicKey.RSA import importKey, construct
|
|
from Crypto.Cipher import PKCS1_v1_5
|
|
except:
|
|
print("检测到还未安装 pycryptdemo 请按照md的方法安装")
|
|
exit(0)
|
|
from base64 import b64encode
|
|
|
|
|
|
class RSA_Encrypt:
|
|
def __init__(self, key):
|
|
if isinstance(key, str):
|
|
# 若提供的rsa公钥不为pem格式 则先将hex转化为pem格式
|
|
# self.key = bytes.fromhex(key) if "PUBLIC KEY" not in key else key.encode()
|
|
self.key = self.public_key(key) if "PUBLIC KEY" not in key else key.encode()
|
|
else:
|
|
print("提供的公钥格式不正确")
|
|
|
|
def public_key(self, rsaExponent, rsaModulus=10001):
|
|
e = int(rsaExponent, 16)
|
|
n = int(rsaModulus, 16) # snipped for brevity
|
|
pubkey = construct((n, e)).export_key()
|
|
return pubkey
|
|
|
|
def encrypt(self, data, b64=False):
|
|
pub_key = importKey(self.key)
|
|
cipher = PKCS1_v1_5.new(pub_key)
|
|
rsa_text = cipher.encrypt(data.encode("utf8"))
|
|
rsa_text = b64encode(rsa_text).decode() if b64 else rsa_text.hex()
|
|
return rsa_text
|