什么是web services?
Web Services 是一种平台中立的网络服务,应用程序可以通过 URL 指定存取 internet 上任何一台电脑提供的服务,不管对方的电脑是什么作业平台或应用程式的原型,双方只要遵循标准的协定就可以溝通。
简单的说就是一个应用程序它向外届暴露出一个能远程进行调用的程序。
web service实现的框架:Axis 1/ Axis 2
sxf
Xfire
目前我们用到的是Axis2.
封装web服务请求时可以穿越防火墙的因为web service和website使用同样的端口(默认8080)一般防火墙不会封装这个端口。
Web Services的起源
Web应用的巨大成功和不断发展,使其渗透到商业领域和个人生活的各个方面。人们只要使用浏览器,就可以享受到各种各样的Web服务,例如网上购物,网上交易,网络游戏,预定车票,网上聊天和交友等等。与此同时,由于Web技术所带来的优势(统一的客户端和较好的维护性),使一些传统的应用纷纷转型到BS结构上。
然而,在发展中,逐步暴露了一些问题。所有这些Web页面都是为人准备的,是让人去阅读,去输入,去判断。因此各种反映视觉效果的内容占用了大量的网络带宽,例如各种图片,字体信息,文字排版样式等。而真正含有高价值的一些信息,被深深埋在这些显示信息中,很难被其他应用和程序所使用。更重要的是,各种web服务之间缺少交互和通讯的机制。
為什麼要有 Web Services?
(简单的说web services就是为了方便测试,因为通过远程协议访问调用可测试的)
前面已經大略點出,Web Services 基於其平台中立以及 internet 無遠弗屆的特性,將可提高軟體元件的重複使用率,這是它的好處之一,除此之外,我們還可以從企業的需求以及技術面兩種角度來探討為什麼需要 Web Services
Web Services的基本原理
Web Services 是通过一系列标准和协议来保证程序之间的动态连接。其中最基本的协议包括:SOAP, WSDL, UDDI
◆SOAP (Simple Object Access Protocol,远程调用)
◆UDDI (Universal Description, Discovery and Integration Service贸易,目录服务)
◆WSDL (描述服务特征)
◆XLANG/XAML (为包括多种web services的复杂web事务提供支持)
◆XKMS (XML Key Management Specification) - 支持认证和注册,这个工作还在进展之中
SOAP: 是“Simple Object Access Protocol”的缩写,SOAP是消息传递的协议,它规定了Web Services之间是怎样传递信息的。简单的说,SOAP规定了:
1. 传递信息的格式为XML。这就使Web Services能够在任何平台上,用任何语言进行实现。
2. 远程对象方法调用的格式。规定了怎样表示被调用对象以及调用的方法名称和参数类型等。
3. 参数类型和XML格式之间的映射。这是因为,被调用的方法有时候需要传递一个复杂的参数,例如,一个Person对象。怎样用XML来表示一个对象参数,也是SOAP所定义的范围。
4. 异常处理以及其他的相关信息.
WSDL:是“Web Services Description Language”的缩写.意如其名,WSDL是Web Services的定义语言。当你实现了某种服务的时候(如,股票查询服务),为了让别的程序调用,你必须告诉大家你的服务的接口.例如,服务名称,服务所在的机器名称,监听端口号,传递参数的类型,个数和顺序,返回结果的类型等等.这样别的应用程序才能调用你的服务。WSDL协议就是规定了有关Web Services描述的标准。
UDDI: 是Universal Description, Discovery, and Integration的缩写。简单说,UDDI用于集中存放和查找WSDL描述文件,起着目录服务器的作用。
如上图,一个Web Services的生命周期是:
实现一个Web Services,使其能够接受和响应SOAP消息(现在有很多工具都可以帮助实现)。
撰写一个WSDL文件用于描述此Web Services。(现在有很多工具可以自动生成WSDL文件)。
将此WSDL发布到UDDI上。
其他的应用程序(客户端)从UDDI上搜索到你的WSDL。
根据你的WSDL,客户端可以编写程序(现在有很多工具可以自动生成调用程序)调用你的Web Services。
Web Services的缺点
由于是基于XML的应用,Web Services与生俱来地在拥有XML带来的一切优势的同时,不可避免地继承了XML所带来的一些限制。
Web Services通常需要大量的CPU资源。因为XML数据要经过多步处理才能被系统使用。首先是效验(validate),检查它的格式是否符合XML的规范,以及根据应用程序定义(DTD或Schema)检查是否符合语义上的规范;然后还要进行解析(parse),从XML文档分解出单个的元素;最后还要转换成应用程序所需要的二进制表达(例如,把“12” 转换成整型12的二进制表示)。
Web Services还意味着占用较多的内存资源。在进行XML解析的时候,会产生大量的临时内存对象。特别是在处理DOM对象的时候。这些大量的临时对象对于象JAVA这类自动回收内存的语言和系统其实是一种负担,大量的临时对象将会使系统每隔一段时间就会进行内存回收,从而降低系统的性能。当然,现在有的Web Services的产品(如axis)采用了SAX技术,大大减少了内存的占用量。详细信息请参考:(http://xml.apache.org/axis/index.html)。
网络资源的消耗也是Web Services应用的一些限制。因为基于XML数据的传递通常数据量要比二进制的协议(如RMI/IIOP)要大的多。这种额外的消耗在网络资源比较紧张或网络传输比较频繁的应用中会产生一定的影响。
简单的说web services优缺点:
优点:分布式的网络应用程序,
基于HTTP协议 跨防火墙,
可重用
跨语言,跨平台
缺点:访问速度慢,稳定性问题。
在项目中要注意的问题:对象要序列化,日期要转化格式String型,集合不支持要转化为数组,byte型要转化为流
总结
一旦Web Services得到更加广泛的应用,使得各种服务可以动态查找和定位,这样就提供了不同设备之间各种各样的信息交互方式,将会大大改变商业运做的模式和信息交流的风格。
你可以使用别人已经成熟的功能来使自己提供更好的服务,例如google,它的搜索引擎可以通过Web Services来访问。这就意味着在你的系统中可以方便的嵌入使用google的强大搜索功能,而不论你的系统是运行在什么平台上,使google的搜索引擎成为你系统的一部分,(请参考http://www.google.com/apis/)。站在别人的肩膀上,毕竟要看得远些!
面对Web Services,你现在可以不行动,但你一定要准备好!