python 中使用 M2Crypto 想读写文件时总是报:
windows 平台下使用 openssl 时不能直接操作与文件 IO 有关的函数。
因为 ms/uplink.c 会动态从当前 exe 中获取 ms/applink.c 的函数表,逻辑是
。如果想使用,则必须在链接 exe 时候也链接 ms/uplink.c。
当 python 使用 M2Crypto 时,如果操作文件,可先创建一个 MemoryBuffer 的 BIO 对象, 然后将 MemoryBuffer 读取为字符串,手动将字符串写入文件。
print "Generating a 1024 bit private/public key pair for Bob..."
Bob = M2Crypto.RSA.gen_key (1024, 65537) if os.name == 'nt':
mb = M2Crypto.BIO.MemoryBuffer()
Bob.save_key_bio(mb, None)
with open('Bob-private.pem', 'wb') as f:
f.write(mb.read_all())
else:
Bob.save_key ('Bob-private.pem', None)
读时顺序相反,先读为字符串,然后创建 MemoryBuffer 的 BIO 对象,接着用 BIO 创建所需对象
if os.name == 'nt':
mb = None
with open('Bob-private.pem', 'rb') as f:
mb = M2Crypto.BIO.MemoryBuffer(f.read()) if mb:
Bob = M2Crypto.RSA.load_key_bio(mb)
else:
print 'error load key'
else:
Bob = M2Crypto.RSA.load_key('Bob-private.pem')