suds WebFault 可能的错误 SOAPAction

0 投票
1 回答
2875 浏览
提问于 2025-04-18 01:15

我查看了其他类似的问题,但没有发现和我遇到的情况完全相同。所以我决定同时发这个问题给suds和pysimplesoap。我不在乎用哪个,只希望能尽快让其中一个工作起来。我觉得问题可能出在一个用.NET创建的服务生成的WSDL文件上,因为我在使用pysimplesoap和其他所有尝试过的Python SOAP客户端时都遇到了同样的问题。我用suds和suds-jurko都试过,结果也是一样。我对SOAP这块不太熟悉(我更喜欢用简单的RESTful服务和JSON),所以任何帮助都非常感谢。我会给有用的回答点赞并标记为解决方案。

这是WSDL文件的链接

这是我的代码:

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这个前缀。

撰写回答