簡體   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