0

我一直在努力让 Cisco Call Manager 的 AXL 使用 Python 而不是 php(我让它运行没有问题),并且遇到了问题。我已经花了几个小时来反对它,所以我认为是时候征求外部意见,看看你是否能提供任何见解。我的净化代码如下:

from suds.client import Client
from suds.transport.https import HttpAuthenticated
import logging

logging.basicConfig(level=logging.CRITICAL)
logging.getLogger('suds.client').setLevel(logging.DEBUG)
logging.getLogger('suds.transport').setLevel(logging.CRITICAL)
logging.getLogger('suds.xsd.schema').setLevel(logging.CRITICAL)
logging.getLogger('suds.wsdl').setLevel(logging.CRITICAL)

service = 'https://IPADDRESS:PORT/axl/'

wsdl = 'file:///PATH/TO/LOCAL/WSDL/AXLAPI.wsdl'

username = "username"

password = "password"

client = Client(wsdl, location = service, transport = HttpAuthenticated(username = username, password = password))

name = "NAME_DP"

tags = ["regionName"]

print "<THIS IS A LISTDEVICEPOOL REQUEST>"
dp = client.factory.create('ns0:ListDevicePoolReq')
dp.searchCriteria.name = name
dp.returnedTags = tags
result = client.service.listDevicePool(dp)
print "<THIS IS THE RESULT>"
print result

问题是肥皂输出最终是:

DEBUG:suds.client:headers = {'SOAPAction': u'"CUCM:DB ver=8.5 listDevicePool"',
'Content-Type': 'text/xml; charset=utf-8'}
ERROR:suds.client:<?xml version="1.0" encoding="UTF-8"?>
<SOAP-ENV:Envelope xmlns:ns0="http://www.cisco.com/AXL/API/8.5" xmlns:ns1="http:
//schemas.xmlsoap.org/soap/envelope/" xmlns:xsi="http://www.w3.org/2001/XMLSchem
a-instance" xmlns:SOAP-ENV="http://schemas.xmlsoap.org/soap/envelope/">
   <SOAP-ENV:Header/>
   <ns1:Body>
      <ns0:listDevicePool>
         <searchCriteria>
            <searchCriteria>
               <name>NAME_DP</name>
            </searchCriteria>
            <returnedTags>regionName</returnedTags>
         </searchCriteria>
      </ns0:listDevicePool>
   </ns1:Body>
</SOAP-ENV:Envelope>
DEBUG:suds.client:http failed:
<?xml version='1.0' encoding='utf-8'?><soapenv:Envelope xmlns:soapenv="http://sc
hemas.xmlsoap.org/soap/envelope/"><soapenv:Body><soapenv:Fault><faultcode>soapen
v:Server</faultcode><faultstring>Usage: Required returnedTags as empty tag or sh
ould contain requested tags</faultstring><detail><axlError><axlcode>5003</axlcod
e><axlmessage>Usage: Required returnedTags as empty tag or should contain reques
ted tags</axlmessage><request>listDevicePool</request></axlError></detail></soap
env:Fault></soapenv:Body></soapenv:Envelope>
Traceback (most recent call last):
  File "C:\Users\C53170\Desktop\sudstest\barebones.py", line 39, in <module>
    result = client.service.listDevicePool(dp)
  File "C:\Python27\lib\site-packages\suds\client.py", line 542, in __call__
    return client.invoke(args, kwargs)
  File "C:\Python27\lib\site-packages\suds\client.py", line 602, in invoke
    result = self.send(soapenv)
  File "C:\Python27\lib\site-packages\suds\client.py", line 649, in send
    result = self.failed(binding, e)
  File "C:\Python27\lib\site-packages\suds\client.py", line 702, in failed
    r, p = binding.get_fault(reply)
  File "C:\Python27\lib\site-packages\suds\bindings\binding.py", line 265, in ge
t_fault
    raise WebFault(p, faultroot)
suds.WebFault: Server raised fault: 'Usage: Required returnedTags as empty tag or should         contain requested tags'

如您所见,它将所有内容(包括定义的 searchCriteria)嵌套在 searchCriteria 属性中,这导致返回的标签属性被视为 searchCriteria 的一部分。我无法找出原因或确定如何纠正它。这是如何导入 wsdl 的问题吗?

如果您需要查看导入的 wsdl 或 xsd 文件,请告诉我。它们非常大,我无法从这台计算机上访问 pastebin 或 google 文档(在工作中被阻止),但我可以找到一些地方将它们扔掉。

预先感谢您的协助!

4

1 回答 1

0

这是 listPhone 的代码,但它也应该适用于 listPoolDevice。使用我的代码中的调试和日志命令来查看您的请求在发送时的外观,但我认为这将解决您的问题并让您开始使用带有 CUCM 和 AXL 的 python。

from suds.client import Client

cmserver = '10.10.10.10'
cmport = '8443'
wsdl = 'file:///your/system/path/schema/current/AXLAPI.wsdl'
location = 'https://' + cmserver + ':' + cmport + '/axl/'
username = 'username'
password = 'password'

client = Client(wsdl,location=location, username=username, password=password)

result = client.service.listPhone({'name':'SEP%'},{'name':'','model':''})

for node in result['return']['phone']:
    print str(node['name']), str(node['model'])
于 2014-12-01T23:19:50.880 回答