Python的Web编程[2] -> WebService技术[0] -> 利用 Python 调用 WebService 接口
WebService技术 / WebService Technology
1 关于webservice / Constants
WebService是一种跨编程语言和跨操作系统平台的远程调用技术。
WebService主要由以下三种技术构成,XML+XSD,SOAP和WSDL
XML+XSD:
WebService采用HTTP协议传输数据,采用XML格式封装数据(即XML中说明调用远程服务对象的哪个方法,传递的参数是什么,以及服务对象的返回结果是什么)。XML是WebService平台中表示数据的格式。除了易于建立和易于分析外,XML主要的优点在于它既是平台无关的,又是厂商无关的。无关性是比技术优越性更重要的:软件厂商是不会选择一个由竞争对手所发明的技术的。
XML解决了数据表示的问题,但它没有定义一套标准的数据类型,更没有说怎么去扩展这套数据类型。例如,整形数到底代表什么?16位,32位,64位?这些细节对实现互操作性很重要。XML Schema(XSD)就是专门解决这个问题的一套标准。它定义了一套标准的数据类型,并给出了一种语言来扩展这套数据类型。WebService平台就是用XSD来作为其数据类型系统的。当你用某种语言(如VB.NET或C#)来构造一个Web service时,为了符合WebService标准,所有你使用的数据类型都必须被转换为XSD类型。你用的工具可能已经自动帮你完成了这个转换,但你很可能会根据你的需要修改一下转换过程。
SOAP:
WebService通过HTTP协议发送请求和接收结果时,发送的请求内容和结果内容都采用XML格式封装,并增加了一些特定的HTTP消息头,以说明HTTP消息的内容格式,这些特定的HTTP消息头和XML内容格式就是SOAP协议。SOAP提供了标准的RPC方法来调用Web Service。
SOAP协议 = HTTP协议 + XML数据格式
SOAP协议定义了SOAP消息的格式,SOAP协议是基于HTTP协议的,SOAP也是基于XML和XSD的,XML是SOAP的数据编码方式。打个比喻:HTTP就是普通公路,XML就是中间的绿色隔离带和两边的防护栏,SOAP就是普通公路经过加隔离带和防护栏改造过的高速公路。
WSDL:
好比我们去商店买东西,首先要知道商店里有什么东西可买,然后再来购买,商家的做法就是张贴广告海报。 WebService也一样,WebService客户端要调用一个WebService服务,首先要有知道这个服务的地址在哪,以及这个服务里有什么方法可以调用,所以,WebService务器端首先要通过一个WSDL文件来说明自己家里有啥服务可以对外调用,服务是什么(服务中有哪些方法,方法接受的参数是什么,返回值是什么),服务的网络地址用哪个url地址表示,服务通过什么方式来调用。
WSDL(Web Services Description Language)就是这样一个基于XML的语言,用于描述Web Service及其函数、参数和返回值。它是WebService客户端和服务器端都能理解的标准格式。因为是基于XML的,所以WSDL既是机器可阅读的,又是人可阅读的,这将是一个很大的好处。一些最新的开发工具既能根据你的Web service生成WSDL文档,又能导入WSDL文档,生成调用相应WebService的代理类代码。
WSDL文件保存在Web服务器上,通过一个url地址就可以访问到它。客户端要调用一个WebService服务之前,要知道该服务的WSDL文件的地址。WebService服务提供商可以通过两种方式来暴露它的WSDL文件地址:1.注册到UDDI服务器,以便被人查找; 2.直接告诉给客户端调用者。
2 suds模块 / suds Module
Python中可以利用suds模块实现对WebService的调用。
环境安装:
pip install suds-jurko
使用方法:
(1) 建立初始数据,用户名/密码/url(url常为WSDL页面)等
(2) 实例化Client,print出实例化后的client可以查看WSDL上的函数及参数等
(3) 利用client.servic对WSDL定义的方法调用
示例代码:
下面的代码是一个简单的调用示例,可以通过 print 获得的实例来查看所有可调用的函数接口。
from suds.client import Client class BarApixServiceException(Exception): pass class BarApixWrongUser(Exception): pass class BarApixIDNotFoundException(Exception): pass class Service(): def __init__(self, url, userid, password, barApix_id, timeout=0): self.client = None self.userid = userid self.password = password self.barApix_id = barApix_id try: if timeout == 0: self.client = Client(url=url) else: self.client = Client(url=url, timeout=timeout) except: raise BarApixServiceException # Show the function of service # print(self.client) self.login() def login(self): try: response = self.client.service.WS_XStartup(self.userid, self.password) # print(response) if response['WS_XStartupResult'] == 0: raise BarApixWrongUser print('=== Login in success') except: raise BarApixServiceException def get_id_info(self): try: response = self.client.service.WS_XGetIdInfoBaso(self.userid, self.barApix_id) if response['WS_XGetIdInfoBasoResult'] == 0: raise BarApixIDNotFoundException except: raise BarApixServiceException return_response = {} for r in response: if isinstance(r[1], str): return_response[str(r[0])] = str(r[1].strip()) else: # Handle None value return_response[str(r[0])] = r[1] print(return_response) return return_response def get_test_status(self): try: response = self.client.service.WS_XGetTestStatus(self.userid, self.barApix_id) if response['WS_XGetTestStatusResult'] == 0: raise BarApixIDNotFoundException except: raise BarApixServiceException return_response = response return return_response info = {'service_1': {'userid': 'user1', 'password': 'password', 'barApix_id': ['Dxxxxx'], 'url': 'http://xxxxx/BarApix/BarApixService/?wsdl' }, 'service_2': {'userid': 'user2', 'password': 'password', 'barApix_id': ['Cxxxxx'], 'url': 'http://xxxxxxx/BarApix/BarApixService/?wsdl' }, } user = info['service_1'] service = Service(user['url'], user['userid'], user['password'], user['barApix_id'][0]) # More Function please check 'barApixFunc.txt' service.get_id_info() service.get_test_status()
参考链接
http://blog.csdn.net/wooshn/article/details/8069087/
http://www.cnblogs.com/walkerwang/archive/2011/07/27/2118401.html