WebService(二)

WsExplorer和Tcp/Ip Monitor工具本身就存在于eclipse和MyEclipse中
使用工具的原因:
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:这是发出的消息格式:
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/" xmlns:q0="http://WebXml.com.cn/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
- <soapenv:Body>
- <q0:qqCheckOnline>
  <q0:qqCode>870931520</q0:qqCode> 
  </q0:qqCheckOnline>
  </soapenv:Body>
  </soapenv:Envelope>
2:以下是接收到的XML格式
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
- <soap:Body>
- <qqCheckOnlineResponse xmlns="http://WebXml.com.cn/">
  <qqCheckOnlineResult>N</qqCheckOnlineResult> 
  </qqCheckOnlineResponse>
  </soap:Body>
  </soap:Envelope>

采用qqOnlineWebServiceHttpGet或qqOnlineWebServiceHttpPost中的qqCheckOnline验证时,返回的都是
<?xml version="1.0" encoding="utf-8"?>
<string xmlns="http://WebXml.com.cn/">N</string>

使用Tcp/Ip Monitor
TCP/IP Monitor不仅可以看到SOAP数据,还可以获取HTTP请求和接收的头信息。
1、位置:此工具位于:window>show view>other>MyEclipse Common(常用工具)>TCP/IP Monitor
2、此工具,相当于一个代理商,启动后它将监听本地的某个端口,然后再将请求转发给指定的目标IP和端口。
获取到数据后,再将数据原封不动的返回给客户。在客户看来,永远首先访问的都应该是这个代理,否则我们将看不到数据传输的过程。
4、	配置选项:
在打开的TCP/IP Monitor界面上:view Menu(右上方向下的小箭头)>Properties>Add(右侧添加)
设置成以下属性:
第一步:
1)local monitoring port(监听本地的端口号):9876,随意设置一个4位的端口号,一会将通过http://127.0.0.1:9876的形式访问
2)host name(要监听的服务器,如www.baidu.com):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,然后通过在地址栏输入:http://127.0.0.1:9876/helloworld?wsdl,在返回的wsdl文件中查看:<soap:address location=“http:……”/>处地址的变化情况。
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);
}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在上一篇教程中,我们讲解了如何创建一个C#的WebService,并且通过SOAP协议来调用它。这篇教程中,我们将会介绍如何通过Delphi来调用这个WebService。 首先,我们需要在Delphi中创建一个新项目。在菜单栏中选择“文件” → “新建” → “VCL Forms 应用程序”。接着,在“工具箱”中选择“SOAP 连接”,将其拖拽到窗体上。 现在,在窗体上双击SOAP连接,打开“SOAP 连接编辑器”。在“WSDL URL”中输入我们上一篇教程中创建的WebService的URL地址,然后点击“导入”按钮。Delphi将会自动解析WebService并生成相应的代码。 接下来,我们需要创建一个按钮并为其添加一个OnClick事件。在事件处理程序中,我们可以调用WebService的方法并获取返回值。以下是示例代码: ```delphi procedure TForm1.Button1Click(Sender: TObject); var service: Service1Soap; str: string; begin service := GetService1Soap(); str := service.HelloWorld(); ShowMessage(str); end; ``` 在这个示例中,我们首先创建了一个Service1Soap类型的变量service,然后通过GetService1Soap函数获取WebService的实例。接着,我们调用了WebService中的HelloWorld方法,并将返回值赋值给了str变量。最后,我们通过ShowMessage函数显示了返回值。 现在,我们可以运行程序并点击按钮来测试我们的WebService是否能够正常工作了。 总结: 通过Delphi来调用C#的WebService非常简单。我们只需要使用Delphi自带的SOAP连接组件,并通过Get函数获取WebService的实例就可以了。如果你还没有尝试过这个功能,那么我建议你花费一些时间来学习它。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值