Bootstrap

RSA用私钥加密数据公钥解密数据(不是签名验证过程)

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

成功。 

;