在上篇文章给大家介绍了webservice教程详解(一)
使用工具的原因:
1、 使用工具可以更好的了解webservice请求的过程
2、 使用工具wsexplore可以获取soap数据发送和接收的格式
3、 使用工具tcp/ip monitor可以监控拦截器请求头和响应头的具体数据
什么是soap?
soap是一种基于xml编码规范的文本协议,简单的说soap就是在http的基础上传输xml数据,以实现远程调用【无论你的服务端是什么语言书写的,只要接收soap协议的xml数据,并返回soap协议的xml数据,就可以被任何语言调用】
使用wsexplorer实例:验证qq是否在线
采用qqonlinewebservicesoap中的qqcheckonline验证时,返回的是
qqcheckonlineresponse
qqcheckonlineresult (string): n
点击source可以看到详细信息,信息如下:
1:这是发出的消息格式:
代码如下:
2:以下是接收到的xml格式
代码如下:
采用qqonlinewebservicehttpget或qqonlinewebservicehttppost中的qqcheckonline验证时,返回的都是
nhttp://webxml.com.cn/">n>
使用tcp/ip monitor
tcp/ip monitor不仅可以看到soap数据,还可以获取http请求和接收的头信息。
1、位置:此工具位于:window>show view>other>myeclipse common(常用工具)>tcp/ip monitor
2、此工具,相当于一个代理商,启动后它将监听本地的某个端口,然后再将请求转发给指定的目标ip和端口。
获取到数据后,再将数据原封不动的返回给客户。在客户看来,永远首先访问的都应该是这个代理,否则我们将看不到数据传输的过程。
3、 配置选项:
在打开的tcp/ip monitor界面上:view menu(右上方向下的小箭头)>properties>add(右侧添加)
设置成以下属性:
第一步:
1)local monitoring port(监听本地的端口号):9876,随意设置一个4位的端口号,一会将通过http://127.0.0.1:9876的形式访问
2)host name(要监听的服务器,如www.jb51.net):127.0.0.1 –因为本机发布了一个webservice所以监听本机ip.也可以是任意的主机。
3)port(要监听的目标服务器的端口):6666 - 因为我们发布的webservice为http://127.0.0.1:6666/helloworld所以,6666是需要监听的端口号。
4)type(监听的类型):
-- tcp/ip : 将使用原始地址继续访问下一个请求,如用户输入:http://127.0.0.1:9876/helloworld?wsdl此时将返回wsdl服务访问地址同前。
-- http :将使用目标地址继续访问下一个请求。如用户输入: http://127.0.0.1:9876/helloworld?wsdl在请求方法时将使用http://127.0.0.1:6666/helloworld来访问sayhi方法。此种方式将不再会被代理。因为已经不是正在监听的端口号了。
在监听类型处,我选择了tcp/ip,然后通过在地址栏输入:,在返回的wsdl文件中查看:处地址的变化情况。
time out:设置访问不成功的连接时间,保持为0,即不设置。
在设置好后,点ok按扭,然后再点右方的start按扭,监听便已经启动。
第二步:
在myeclipse的webservice上配置wsdl url为:http://127.0.0.1:9876/helloworld?wsdl,注意使用的是myeclipse tcp/ip monitor的端口。而不是直接去访问我们发布的http://127.0.0.1:6666/helloworld?wsdl
如何修改wsdl文件的内容?
使用webservice的注解。
1、 @webservice-定义服务
2、 @webmethod-定义方法
3、 @webresult-定义返回值
4、@webparam-定义参数
注意:对于注解,不同的版本支持程度不相同:
1、1.5不支持.
2、1.6.0_20前版本必须使用完整注解.
3、1.6.0_21以后可以只使用@webservice对类进行注解.
注释的作用:
通过webservice的注解,可以更加形像的描述web服务。从而生成wsdl文档。
当修改了webservice注解之后,同时会影响客户端生成的代码。
调用的方法名和参数名也发生了变化。
示例:
@webservice(name="myname",//对应porttype name="myname" portname="myport", //对应服务中的port name="myport" servicename="myservice",//对应service name="myservice" targetnamespace="http://leaf.com/mynamespace")//可以随意书写类似于java中的package public class helloworld{ private static simpledateformat sdf = new simpledateformat("yyyy-mm-dd hh:mm:ss"); @webmethod(action="myaction",//定义一个soapaction="myaction"用于找到这个方法以执行 operationname="myoperationname")//定义可以调用的方法,会生成相应类的具体方法,operation name=".." public @webresult(name="mysayhelloresult")string//定义返回值的名称 sayhello(){ return "helloworld"; } @webmethod(action="mysayhiaction",operationname="mysayhioperationname") public @webresult(name="mysayhiresult")string sayhi(@webparam(name="myparaname", //将参数放到头信息中,用于保护参数,默认在body中 header=true, mode=mode.in) string name){ string str = "你好:"+name+",当前时间是:"+sdf.format(new date()); return str; } public static void main(string[] args) { endpoint.publish("http://127.0.0.1:6666/helloworld",new helloworld()); } }
3:将上面的程序对外发布以后,我们通过myeclipse的webservice explorer来访问
你会发现和以前不一样的提示信息,但其实,仍然还是调用的那同一个方法。
4:再次使用wsimport –s . http://127.0.0.1:6666/helloworld?wsdl生成java代码然后调用
以下是调用代码(可以用面目全非来形容,但完成的还是同样的工作。)
package com.leaf.mynamespace; public class main { public static void main(string[] args) { //通过分析wsdl可知从myservice中调用getmyport返回myname myname myname = new myservice().getmyport(); //通过myname的mysayhioperationname来调用sayhi方法 string str = myname.mysayhioperationname("王健"); system.err.println(str); } }
关于webservice教程详解(二) 就先给大家介绍到这里,希望对大家有所帮助!
如对本文有疑问, 点击进行留言回复!!
NullPointerException: Attempt to invoke virtual method ‘android.content.res.XmlResourceParser androi
关于启动appium-desktop,报错:Cannot extract apk info using apkanalyzer. Falling back to aapt. Original ....
Gradle 发布共享库——如何通过Gradle发布Android依赖库(aar)到 jitpack 公共仓库
Gradle 发布共享库——如何通过Gradle发布java依赖库(jar)到 jitpack 公共仓库(—)
网友评论