from ctypes import *
from binascii import a2b_hex, b2a_hex
#baseCrypt = u"Microsoft Base Cryptographic Provider v1.0"
CryptAcquireContextW = windll.Advapi32.CryptAcquireContextW
CryptImportKey = windll.Advapi32.CryptImportKey
CryptEncrypt = windll.Advapi32.CryptEncrypt
CryptDestroyKey = windll.Advapi32.CryptDestroyKey
CryptReleaseContext = windll.Advapi32.CryptReleaseContext
CryptGenRandom = windll.Advapi32.CryptGenRandom
def gen_key(keyTxt):
rsa_header = '\x06\x02\x00\x00\x00\xa4\x00\x00\x52\x53\x41\x31\x00\x04\x00\x00\x01\x00\x01\x00'
kl = [w for w in a2b_hex(keyTxt[:-6])]
kl.reverse()
return rsa_header + ''.join(kl)
def gen_random():
phProv = c_int()
txt_buf = create_string_buffer(16)
CryptAcquireContextW(byref(phProv), None, None, 1, 0xf0000000)
CryptGenRandom(phProv, 16, txt_buf)
CryptReleaseContext(phProv, None)
return b2a_hex(txt_buf.raw)
def rsa_encrypt(key
一段用Python语言的Ctypes模块调用系统api函数写的rsa加密代码
最新推荐文章于 2023-05-26 12:50:49 发布