suds WebFault 可能的错误 SOAPAction
我查看了其他类似的问题,但没有发现和我遇到的情况完全相同。所以我决定同时发这个问题给suds和pysimplesoap。我不在乎用哪个,只希望能尽快让其中一个工作起来。我觉得问题可能出在一个用.NET创建的服务生成的WSDL文件上,因为我在使用pysimplesoap和其他所有尝试过的Python SOAP客户端时都遇到了同样的问题。我用suds和suds-jurko都试过,结果也是一样。我对SOAP这块不太熟悉(我更喜欢用简单的RESTful服务和JSON),所以任何帮助都非常感谢。我会给有用的回答点赞并标记为解决方案。
这是我的代码:
from suds.client import Client
client = Client('http://url-for-my-service?wsdl')
result = client.service.StartSession('userid','passwd')
这是我收到的错误信息:
ERROR:suds.client:<suds.sax.document.Document instance at 0x28fcbd8>
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
File "/home/rksmith/Projects/soap/venv/local/lib/python2.7/site-packages/suds/client.py", line 521, in __call__
return client.invoke(args, kwargs)
File "/home/rksmith/Projects/soap/venv/local/lib/python2.7/site-packages/suds/client.py", line 581, in invoke
result = self.send(soapenv)
File "/home/rksmith/Projects/soap/venv/local/lib/python2.7/site-packages/suds/client.py", line 619, in send
description=tostr(e), original_soapenv=original_soapenv)
File "/home/rksmith/Projects/soap/venv/local/lib/python2.7/site-packages/suds/client.py", line 670, in process_reply
raise WebFault(fault, replyroot)
suds.WebFault
我其实更喜欢suds,因为我可以开启日志记录DEBUG,这样能得到更多信息:
DEBUG:suds.client:sending to (http://cpldevweb001:3691/Invoke?Handler=CSSoapService)
message:
<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope xmlns:ns3="http://www.w3.org/2001/XMLSchema" xmlns:SOAP-ENC="http://schemas.xmlsoap.org/soap/encoding/" xmlns:ns0="http://schemas.xmlsoap.org/soap/encoding/" xmlns:ns1="urn:CSSoapService" xmlns:ns2="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/" SOAP-ENV:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<SOAP-ENV:Header/>
<ns2:Body>
<ns1:StartSession>
<user xsi:type="ns3:string">userid</user>
<pass xsi:type="ns3:string">passwd</pass>
</ns1:StartSession>
</ns2:Body>
</SOAP-ENV:Envelope>
DEBUG:suds.client:headers = {'SOAPAction': '"#StartSession"', 'Content-Type': 'text/xml; charset=utf-8'}
DEBUG:suds.client:HTTP failed - 500 - Internal Server Error:
<SOAP:Envelope xmlns:SOAP="http://schemas.xmlsoap.org/soap/envelope/">
<SOAP:Body>
<SOAP:Fault>
<faultcode>SOAP:Client</faultcode>
<faultcode>Invalid Request</faultcode>
<detail>Invalid SOAP Request, most probable incorrect SOAPAction</detail>
</SOAP:Fault>
</SOAP:Body>
</SOAP:Envelope>
1 个回答
0
供应商提供了一个可以正常运行的示例客户端,我用TcpMon工具运行它,并对比了发送的XML和suds生成的XML。结果发现问题出在一个空的<SOAP-ENV:Header/>
标签上。
我创建了一个消息插件,用来在发送时过滤掉这个空的Header,现在一切正常了。以下是更新后的代码:
import re
from suds.client import Client
from suds.plugin import MessagePlugin
class HeaderFilter(MessagePlugin):
def sending(self, context):
context.envelope = re.sub(r'<[A-Za-z0-9_\-:]*Header/>', '', context.envelope)
return context
client = Client('http://url-for-my-service?wsdl', plugins=[HeaderFilter()])
result = client.service.StartSession('userid','passwd')
我本可以更具体一点,而不是使用正则表达式,但我不确定它是否总是会使用SOAP-ENV这个前缀。