RSA用私钥加密数据公钥解密数据,严格的来说,并不安全。但是最近在写一个keygen的时候,软件作者是这么用的,所以只能搞一个这样的。
常规自带的一些rsa密码utils里面并没有这种功能。只有封装好的sign和verify函数。但是我们并不需要里面的hash功能。所以单独摘出来以供使用。
https://github.com/sybrenstuvel/python-rsa
克隆这个仓库。我克隆的时间为:2022年7月21日,22:55:29。
最后一条commit hash:c4dc7beb04bea05ed86adb2e4b7f780f173774b8
其实需要pip install rsa,然后在python的site-packages里面修改对应的pkcs1.py文件和__init__文件。之后直接import rsa即可
def encrypt_by_privkey(msg: bytes, priv_key: key.PrivateKey) -> bytes:
# Encrypt the msg with the private key
cleartext = msg
keylength = common.byte_size(priv_key.n)
padded = _pad_for_signing(cleartext, keylength)
payload = transform.bytes2int(padded)
encrypted = priv_key.blinded_encrypt(payload)
block = transform.int2bytes(encrypted, keylength)
return block
def decrypt_by_pubkey(encrypted: bytes, pub_key: key.PublicKey) -> bytes:
keylength = common.byte_size(pub_key.n)
payload = transform.bytes2int(encrypted)
decrypted = core.decrypt_int(payload, pub_key.e, pub_key.n)
clearsig = transform.int2bytes(decrypted, keylength)
sep_idx = clearsig.find(b"\x00", 2)
return clearsig[sep_idx + 1 :]
将上面的改版代码加入rsa/pkcs1.py中。
之后修改rsa/__init__.py
from rsa.pkcs1 import (
encrypt,
decrypt,
encrypt_by_privkey,
decrypt_by_pubkey,
sign,
verify,
DecryptionError,
VerificationError,
find_signature_hash,
sign_hash,
compute_hash,
)
__all__ = [
"newkeys",
"encrypt",
"decrypt",
"sign",
"verify",
"PublicKey",
"PrivateKey",
"DecryptionError",
"VerificationError",
"find_signature_hash",
"compute_hash",
"sign_hash",
"encrypt_by_privkey",
"decrypt_by_pubkey"
]
"encrypt_by_privkey",
"decrypt_by_pubkey"
之后就可以私钥加密普通内容,公钥解密普通内容。
把克隆下来的python-rsa-main这个文件夹名改成py_rsa。之后再py_rsa同级目录下新建py文件:
import py_rsa.rsa as rsa
import base64
pub = rsa.PublicKey.load_pkcs1_openssl_pem(open('pubkey.pem').read())
priv = rsa.PrivateKey.load_pkcs1(open('privkey.pem').read())
message = 'hello world now'.encode()
e = rsa.encrypt_by_privkey(message, priv)
d = rsa.decrypt_by_pubkey(e, pub)
print(d)
print(base64.b64encode(e).decode())
输出:
b'hello world now'
l2zTjZeDrrz2LHTQGn0QFzSYN81W4pYOnuuQrPGPEafh12rwX1rTGYhnuEpNVaghWmXDen45QWoWD3YZvWbOfbA5KMqmJph3UlVu0zvWXNQrSlg9ILJOjfCOdqQLyqzkEtoijIsDWKbr1lr5prh+GOHHPOmlF/jG95Dw2E5YZzU=
使用网站工具检测:
http://tool.chacuo.net/cryptrsapubkey
成功。