2012-10-25 7 views
5

Próbuję podpisać plik XML za pomocą pyxmlsec/xmlsec/libxml2, ale zawiedzie (sigCtx->signValueNode == NULL:error=100:assertion).Znak xmlsec1 działa w wierszu poleceń, ale kończy się niepowodzeniem w kodzie Python

Kiedy uruchomić z linii poleceń działa płynnie:

kod
xmlsec1 sign --output signed.xml --pkcs12 c.pfx --pwd mypwd tobesigned.xml 

My Python:

libxml2.initParser() 
libxml2.substituteEntitiesDefault(1) 
xmlsec.init() 
xmlsec.cryptoAppInit(None) 
xmlsec.cryptoInit() 

doc_xml = libxml2.parseMemory(xml, len(xml)) 
signature_node = xmlsec.findNode(
    doc_xml.getRootElement(), 
    xmlsec.NodeSignature, 
    xmlsec.DSigNs, 
) 

signer = xmlsec.DSigCtx() 

key = xmlsec.cryptoAppKeyLoad(
    filename=str(self.issuer.certificate.path), 
    format=xmlsec.KeyDataFormatPkcs12, 
    pwd=str(self.issuer.certificate_password), 
    pwdCallback=None, 
    pwdCallbackCtx=None, 
) 

signer.signKey = key 
signer.sign(signature_node) # error! 
... 

Pełna śledzenia błędów:

func=xmlSecDSigCtxProcessSignatureNode:file=xmldsig.c:line=463:obj=unknown:subj=dsigCtx->signValueNode == NULL:error=100:assertion: 
func=xmlSecDSigCtxSign:file=xmldsig.c:line=303:obj=unknown:subj=xmlSecDSigCtxSigantureProcessNode:error=1:xmlsec library function failed: 

jakieś wskazówki?

Dzięki!

Odpowiedz

5

xmlsec skompilowano z opcją -DXMLSEC_NO_SIZE_T i pyxmlsec z -UXMLSEC_NO_SIZE_T.

Edit setup.py i dodaj następującą linię po t = tuple(flag[2:].split('='))

if len(t) == 1: t = tuple([t[0],""]) 

działa dobrze po łatanie.

Upewnij się, czyszczenie, odbudować i zainstalować ponownie!

+1

Naprawiono widelec: https://github.com/aricaldeira/pyxmlsec – alanjds

Powiązane problemy