一段用Python语言的Ctypes模块调用系统api函数写的rsa加密代码

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
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值