繁体   English   中英

使用python发送unsigned char

[英]Using python to send unsigned char

我正在做一个与密码学相关的项目。 我在python构建代码。 但加密函数使用C库PBC进行计算。 因此,我制作了一个包含恰当函数的C程序,并将其编译为共享库。 我使用ctypes导入库。 到目前为止,一切都很好。

我现在面临的问题是我需要在库中将一个unsigned char声明为全局变量,我需要通过python套接字将它发送到另一个接收python套接字,在那里它将作为unsigned char传递给图书馆。

现在,当我尝试从库中检索unsigned char

ibc = cdll.LoadLibrary('./libibc.so.1.0.1')
strin = 'some string'
ibc.init_pairing(1, 1, 1)# Initializing the lib
ibc.read_share()
id_str = (c_char * 40)()
id_str.value = strin
ibc.hash_id_s(id_str)    # Passing a char to a function

hsid = (c_ubyte * 1000)()
hsid = c_ubyte.in_dll(ibc, "hid")
ibc.gen_privatekey(hsid, 1, 3) #pass unsigned char to function

最后一行以分段错误结束。 所以我使用以下代码从c本身调用了gen_privatekey函数:

int genprkey(){
    unsigned char key[100];
    element_to_bytes(key, pks);
    gen_privatekey(key, 1, 2);
}

然后我使用python从python调用此函数:

ibc.genprkey()

并且程序成功。

问题

上面的函数生成一个unsigned char ,它也将存储在另一个全局变量中。 我试图检索变量:

hsidp = (c_char_p)()
hsidp = c_char_p.in_dll(ibc, "hid")

我在python解释器上尝试了上面的代码。 当我输入:

hsidp

输出是:

c_char_p(10598250801977757708)

但是当我键入:

hsidp.value

我遇到了segmentation fault (core dumped) 我怀疑我处理变量的方式不正确。 一旦我将unsigned char作为python中的变量,我需要将它作为消息发送到另一个读取它的套接字并将其作为unsigned char传递给同一个库。

我不知道如何做到这一点。 请帮忙

以下是如何访问共享库中的数组:

虚拟图书馆:

>>> from ctypes import *
>>> import os

>>> open('lib.c', 'w').write(
...   'unsigned char data[] = {0, 1, 2, 3};\n')
>>> ret = os.system('gcc -shared -o lib.so lib.c')

加载库并访问长度为4的unsigned char数组

>>> lib = CDLL('./lib.so')
>>> data = (c_ubyte * 4).in_dll(lib, 'data')
>>> list(data)
[0, 1, 2, 3]

此外, c_char_p是一个指针,从数组的前4或8个字节获取该指针将指出谁知道在哪里,因此当您尝试取消引用它时可能会出现段错误。 另外,下面的第一个语句实例化一个指针,当您在第二个语句中重新分配hsidp ,该指针会立即释放:

hsidp = (c_char_p)()   
hsidp = c_char_p.in_dll(ibc, "hid")

同样,下面的第一行创建一个长度为1000的数组并将其抛出。 我不知道为什么。 然后你从库中得到一个字节。

hsid = (c_ubyte * 1000)()
hsid = c_ubyte.in_dll(ibc, "hid")

你需要一个字节或一个字节数组? 什么长度? 或者gen_privatekey是否想要一个指向以null结尾的字符串的指针?


您可以使用string_at来获取Python str对象:

>>> hid = (c_ubyte * 24)(*map(ord, "This is a test."))
>>> string_at(hid, 24)
'This is a test.\x00\x00\x00\x00\x00\x00\x00\x00\x00'

或者你可以从缓冲区创建一个c_char数组(或者只是从一开始就使用它而不是c_ubyte数组):

>>> (c_char * 24).from_buffer(hid).value
'This is a test.'

c_char数组更方便使用字符串,因为它的value和返回Python str对象的raw描述符。 这些描述符还允许您将字符串写入缓冲区:

>>> hid = (c_char * 24)()
>>> hid.value = 'This is a test.'
>>> hid.value
'This is a test.'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM