如何在Spyne中设置端口的名称和绑定?

时间:2017-07-26 11:20:41

标签: python web-services wsdl spyne

我已通过Spyne撰写了Django网络服务。我正在模拟一些应用程序,所以我需要实现精确的接口。我在原始应用程序中遵循port定义:

< wsdl:service name = "SendSmsWebServiceImplService" >
  < wsdl:port binding = "tns:SendSmsWebServiceImplServiceSoapBinding" name = "SendSmsWebServiceImplPort" >
      < soap:address location = "http://192.168.100.31:8181/smsgateway/sendsms" / >
  < / wsdl:port >
< / wsdl:service >

这就是我在模拟器中所拥有的:

< wsdl:service name = "SendSmsWebServiceImplService" >
  < wsdl:port name = "SendSmsWebService" binding = "tns:SendSmsWebService" >
      < soap:address location = "http://127.0.0.1:5000/smsgateway/services/SendSms/" / >
  < / wsdl:port >
< / wsdl:service >

我正在尝试为name设置bindingport。我正在使用模块spyne.application.Application来实现主应用程序。设置这些属性的方法是什么?

1 个答案:

答案 0 :(得分:1)

要更改端口和绑定的名称,可以设置Application类的“name”属性,如下所示:

   app = Application(services=[YourService],
      name='serviceName',
      tns='your.tns',
      in_protocol=Soap11(validator='lxml'),
      out_protocol=Soap11()
   )

但要注意,如果在“services”参数中有多个服务公开,则spyne将为它们分配所有相同的端口/绑定名称。 如果您尝试使用轴使用服务,这可能会导致问题。

如果是这种情况,您可能需要更多spyne.application.Application类的实例。

还有另一种方法可以重命名这些属性。您只需将wsdl保存为xml文件,重命名所需的所有属性,然后在Web服务器上发布xml以代替生成的wsdl。 将此xml文件(带有完整的URL)提供给您的Web服务客户端应该可以正常工作。

希望它有所帮助。