Python 是否为EVP\U MD\U CTX公开_hashlib.pyd内部构件?

Python 是否为EVP\U MD\U CTX公开_hashlib.pyd内部构件?,python,serialization,ctypes,hashlib,Python,Serialization,Ctypes,Hashlib,有人知道如何使用ctypes公开python 2.x_hashlib.pyd内部构件吗?我特别需要提取EVP_MD_CTX结构来序列化python哈希对象。从头文件(在您的例子中是openssl/EVP.h和_hashopenssl.C)映射C结构很简单,但并不总是可以在不同版本之间移植。这是我的环境: from ctypes import * PyObject_HEAD = [ ('ob_refcnt', c_size_t), ('ob_type', c_void_p), ]

有人知道如何使用ctypes公开python 2.x_hashlib.pyd内部构件吗?我特别需要提取EVP_MD_CTX结构来序列化python哈希对象。

从头文件(在您的例子中是openssl/EVP.h和_hashopenssl.C)映射C结构很简单,但并不总是可以在不同版本之间移植。这是我的环境:

from ctypes import *

PyObject_HEAD = [
    ('ob_refcnt', c_size_t),
    ('ob_type', c_void_p),
]

class EVP_MD(Structure):
    _fields_ = [
        ('type', c_int),
        ('pkey_type', c_int),
        ('md_size', c_int),
        ('flags', c_ulong),
        ('init', c_void_p),
        ('update', c_void_p),
        ('final', c_void_p),
        ('copy', c_void_p),
        ('cleanup', c_void_p),
        ('sign', c_void_p),
        ('verify', c_void_p),
        ('required_pkey_type', c_int*5),
        ('block_size', c_int),
        ('ctx_size', c_int),
    ]

class EVP_MD_CTX(Structure):
    _fields_ = [
        ('digest', POINTER(EVP_MD)),
        ('engine', c_void_p),
        ('flags', c_ulong),
        ('md_data', POINTER(c_char)),
    ]

class EVPobject(Structure):
    _fields_ = PyObject_HEAD + [
        ('name', py_object),
        ('ctx', EVP_MD_CTX),
    ]
下面是如何使用它来:


@est,注意:如果您继续使用此解决方案,您将必须跟踪openssl代码:如果openssl代码中的EVP_MD/EVP_MD_CTX发生更改,您的python代码将中断。例如,上面的代码不适用于openssl-0.9.7之前的任何openssl版本。感谢您发布此消息。对于@abbot来说,这段代码需要更新Python 3.5+和2.7.13+(
('ctx',EVP_MD_ctx)
变成
('ctx',POINTER(EVP_MD_ctx))
)。我最终根据以下和其他配方打包了一个库:
import hashlib

hash = hashlib.md5('test')
print hash.hexdigest()

c_evp_obj = cast(c_void_p(id(hash)), POINTER(EVPobject)).contents
ctx = c_evp_obj.ctx
digest = ctx.digest.contents
state = ctx.md_data[:digest.ctx_size]

hash2 = hashlib.md5()
c_evp_obj = cast(c_void_p(id(hash2)), POINTER(EVPobject)).contents
ctx = c_evp_obj.ctx
digest = ctx.digest.contents
memmove(ctx.md_data, state, digest.ctx_size)
print hash2.hexdigest()