python开发Webservice服务
短信预约 -IT技能 免费直播动态提醒
Webservice
记录一下python开发 Web services跨平台,跨语言,跨设备之间的通信。
Web service 三要素
SOAP:SOAP协议
WSDL:Web service描述语言,我的理解是:你服务端的接收字段,字段类型定义,定义的函数,函数名名以及返回的数据的一个描述XML格式
XML:
demo如下:
# coding:utf-8
#第一步:导入相应的包,我是在在python2的环境下,因为soaplib只支持python2,而且soaplib不再更新了,
#估计到2020年废除python2之后,会出现新的包导入ClassModel是为了和数据库连接的。
from soaplib.core.model.clazz import ClassModel
from spyne import Application, rpc, ServiceBase
from spyne import Integer, Unicode, Array
from spyne.protocol.soap import Soap11
from spyne.server.wsgi import WsgiApplication
from wsgiref.simple_server import make_server
import sys
from spyne.model.complex import ComplexModel
from pymysql import connect
import os,base64,logging
#第二步:记录python Web services服务端的logging文件
logging.basicConfig(level=logging.DEBUG, filename='my_server.log')
logging.getLogger('spyne.application.server').setLevel(logging.DEBUG)
# 第三步 声明接收的客户端的变量名,也就是子段,或者xml标签,由于是数据多,就用的复杂性model,
#得声明空间,在客户端创建对象或者字典都可以,作为对象的一个属性,或者字典的key,value来保存数据的传递。
class Project(ComplexModel):
__namespace__ = 'Project'
name = Unicode
phone = Unicode
address = Unicode
location = Unicode
time = Unicode
level = Unicode
message = Unicode
#多少都可以,前提是客户端得给你传过来,你才能接收到,但是客户端有的字段,你这里必须有,否则会报错,
... = ...
#第四步:声明服务的类,类的方法,就是客户端访问的服务,业务逻辑,操作都在这里面,
#project就是字典,或者对象,
class SServices(ServiceBase):
@rpc(Project, _returns=Unicode)
def make_func(self, project):
# return "链接成功,webservice 服务器已接收到数据"
print(project)
#业务逻辑放这里,把接收到的参数就是project,可以保存到数据库,等操作,
print("save success")
# 第五步代码的执行,ip port就是你本地的地址,或者你的ip地址,ifcofig,
#创建服务名:SServices,服务调用的函数是make_func
if __name__ == "__main__":
# ip = '127.0.0.1'
# ip="192.168.10.73"
ip="192.168.1.37"
port = 6667
soap_app = Application([SServices],
'SampleServices',
in_protocol=Soap11(validator="lxml"),
out_protocol=Soap11())
wsgi_app = WsgiApplication(soap_app)
server = make_server(ip, port, wsgi_app)
sys.exit(server.serve_forever())
就能看到你的服务端已开启,一个xml的描述你Web services功能的xml文档
这是自己的理解,望参考!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341