"Python和suds 0.4中的SAXParseException?"

2024-06-06 00:05:47 发布

您现在位置:Python中文网/ 问答频道 /正文

我有一个简单的Python脚本,它使用sud从SOAP web服务中提取数据。它在一台机器上工作得很好,但是当我将它移到另一台有较旧版本Python(2.4.3)的机器上时,我得到了以下堆栈跟踪:

>>> client = suds.client.Client(url, username='xxx', password='xxx', location=service_location, cache=None)
Traceback (most recent call last):
File "<stdin>", line 1, in ?
File "/home/etlsmart/lib/python2.4/site-packages/suds/client.py", line 112, in __init__
    self.wsdl = reader.open(url)
File "build/bdist.linux-i686/egg/suds/reader.py", line 152, in open
File "build/bdist.linux-i686/egg/suds/wsdl.py", line 136, in __init__
File "build/bdist.linux-i686/egg/suds/reader.py", line 79, in open
File "build/bdist.linux-i686/egg/suds/reader.py", line 101, in download
File "/home/etlsmart/lib/python2.4/site-packages/suds/sax/parser.py", line 136, in parse
    sax.parse(source)
File "/usr/lib/python2.4/site-packages/_xmlplus/sax/expatreader.py", line 109, in parse
    xmlreader.IncrementalParser.parse(self, source)
File "/usr/lib/python2.4/site-packages/_xmlplus/sax/xmlreader.py", line 123, in parse
    self.feed(buffer)
File "/usr/lib/python2.4/site-packages/_xmlplus/sax/expatreader.py", line 220, in feed
    self._err_handler.fatalError(exc)
File "/usr/lib/python2.4/site-packages/_xmlplus/sax/handler.py", line 38, in fatalError
    raise exception
xml.sax._exceptions.SAXParseException: <unknown>:18:2: mismatched tag

我已经研究了与缓存相关的各种错误,但这似乎不是问题所在。我禁用了缓存,/tmp/suds在任何情况下都只包含一个版本文件。

这可能与Python版本有关,还是有其他明显的东西需要我尝试?


Tags: inpybuildselfparselibpackagesline
1条回答
网友
1楼 · 发布于 2024-06-06 00:05:47

我也有同样的问题。服务器有应答HTML而不是SOAP。

终结点的响应是HTML错误消息,而不是SOAPXML。由于某种原因,SUDS说“我无法解析这个。停下!”而不是“我无法分析此答案:<;此处回答>;”,即使使用调试日志级别也是如此。

发现使用调试器插入suds.reader:

/usr/lib/python2.6/site-packages/suds/reader.py in download(self, url)
    100         content = ctx.document
    101         sax = Parser()
--> 102         return sax.parse(string=content)
    103 
    104     def cache(self):

看看content,看看它是否是SOAP XML。

祝你好运。

相关问题 更多 >