创建发布Webservice以及wsimport工具

一、 通过wsimport生成本地代理调用WebService

  1、推荐的访问服务方式

  WebService已纳入w3c规范,其他的平台都支持该规范 :J2EE\Php\.NET都支持wsimport 方式,即对远程的WebService生成本地代理,再通过本地代理来访问WebService。客户端通过wsimport的方式生成java语言本地代理,并把远程的服务解析成本地的类和接口。

  A、服务访问要求

  Jdk的版本要在Jdk 1.6.21及以上。

  B、 wsimport的使用

  wsimport命令的位置在JDK安装路径的Bin目录下,wsimport常用语法如下图,下图中的wsimport路径为我自己电脑的JDK路径

  

  

  

  2、具体案例和Java代码实现

  步骤一、

  确定系统Jdk环境与Eclipse Jdk环境一致,版本在1.6.021以上

  步骤二、

  知道服务端的WSDL路径(WSDL后面有详细介绍),如本次调用查询手机归属地服务的具体路径如下:

  http://webservice.webxml.com.cn/WebServices/MobileCodeWS.asmx?WSDL

步骤三、

  使用JDK1.6以上版本的wsimport命令获得服务端的class文件,生成本地代理

  示例命令如下,其中-s D:\test为指定class文件的存储路径

    

  步骤四、

  在指定的路径下找到服务端的class文件(步骤3路径为D:\test),默认会生成指定的包名cn.com.webxml,并将该包导入新建项目中。

  

  步骤五、

  编写Java代码获取相应的服务数据,具体代码实现如下:

  

  返回结果如下:

  

二、 创建并发布自己的WebService

  1、编写WebService的服务端并发布

  如果要编写WebService的服务端并发布,需要编写业务类,该类通过WebService对外提供服务,要做以下工作

A、声明:@webservice

  B、发布:调用EndPoint方法

  下面为一个创建并发布服务的案例以及Java代码实现

  步骤一、

  编写业务类,并在业务类的类名之上添加@webservice注解,如下示例为编写一个手机操作系统信息类,用以提供不同手机操作系统对应的发展历史,所属公司以及别名。首先编写手机的Bean,为其配置三个属性和添加getter和setter方法。

  

  步骤二、

  编写该业务类的发布方法,指定发布的地址和具体的业务实现类,注意浏览服务具体信息时,地址后面需添加“?WSDL”代码如下,运行即可发布服务。

  步骤三、

  访问服务的具体说明路径,上例中生成的路径为:

  http://127.0.0.1:8888/webservice/phoneservice?WSDL

  访问该路径,看到生成对应的服务名以及方法则服务发布成功,如下图

  

  2、调用自己发布的服务

  如果要调用自己编写的上例中的WebService,可以使用上文介绍的通过wsimport生成本地代理的方式来调用,通过wsimport的方式生成java语言本地代理,并把远程的服务解析成本地的类和接口,之后导包,导包如下。

  

  之后编写测试类调用自己的服务,代码如下:

  

  输出结果如下:

  

原文地址:https://www.cnblogs.com/jiyukai/p/9249026.html

时间: 2024-12-30 01:47:32

创建发布Webservice以及wsimport工具的相关文章

基于jdk wsimport工具访问外部webservice

一.Wsimport简介 Wsimport是jdk自带的,可以根据wsdl文档生成客户点调用代码的工具.无论服务器端的webservice是用什么语言写的,都将在客户端生成java代码.服务器端用什么语言写的并不重要.Wsimport位于JAVA_HOME/bin目录下.Wsimport常用的参数有: -d<目录>  --将生成.class文件.默认参数 -s<目录>  --将生成.java文件. -p<生成的新包名>  --将生成类放于指定的包下 (Wsdlurl)

基于jdk wsimport工具訪问外部webservice

一.Wsimport简单介绍 Wsimport是jdk自带的.能够依据wsdl文档生成客户点调用代码的工具. 不管server端的webservice是用什么语言写的,都将在client生成java代码. server端用什么语言写的并不重要. Wsimport位于JAVA_HOME/bin文件夹下.Wsimport经常使用的參数有: -d<文件夹>  --将生成.class文件. 默认參数 -s<文件夹>  --将生成.java文件. -p<生成的新包名>  --将生

用JAXWS-RI在Tomcat中发布WebService

JDK中已经内置了Webservice发布,不过要用Tomcat等Web服务器发布WebService,还需要用第三方Webservice框架.Axis2和CXF是目前最流行的Webservice框架,这两个框架各有优点,不过都属于重量级框架. JAXWS-RI是JAX WebService参考实现.相对于Axis2和CXF,JAXWS-RI是一个轻量级的框架.虽然是个轻量级框架,JAXWS-RI也提供了在Web服务器中发布Webservice的功能.官网地址https://jax-ws.jav

axis2 发布webservice

一.简介 Apache Axis2是下一代 Apache Axis.Axis2 虽然由 Axis 1.x 处理程序模型提供支持,但它具有更强的灵活性并可扩展到新的体系结构.Axis2 基于新的体系结构进行了全新编写,而且没有采用 Axis 1.x 的常用代码.支持开发 Axis2 的动力是探寻模块化更强.灵活性更高和更有效的体系结构,这种体系结构可以很容易地插入到其他相关 Web 服务标准和协议(如 WS-Security.WS-ReliableMessaging 等)的实现中.Apache A

JAVA项目中发布WebService服务——简单实例

1,在Java项目中发布一个WebService服务: 如何发布? --JDK1.6中JAX-WS规范定义了如何发布一个WebService服务: (1)用jdk1.6.0_21以后的版本发布: (2)与Web服务相关的类,都位于Javax.jws.*包中 @WebService--此注解用在类上指定将此类发布成一个WebService: EndPoint--此类为端点服务类,其中publish()方法用于将一个已经添加了@WebService注解对象绑定到一个地址的端口上,用于发布. 2,例子

真正的轻量级WebService框架——使用JAX-WS(JWS)发布WebService

WebService历来都很受重视,特别是Java阵营,WebService框架和技术层出不穷.知名的XFile(新的如CXF).Axis1.Axis2等. 而Sun公司也不甘落后,从早期的JAX-RPC到现在成熟的.支持RPC调用与消息传递的JAX-WS都经过了市场的考验,十分成熟,而且使用JAX-WS开发WebService的收益是很大的,它是轻量级的. 我们使用JAX-WS开发WebService只需要很简单的几个步骤:写接口和实现=>发布=>生成客户端(测试或使用). 而在开发阶段我们

Spring+CXF+Maven发布Webservice

使用CXF发布WebService简单又快速,还可以与Spring集成,当Web容器启动时一起发布WebService服务.本例是简单的客户端给服务端发送订单信息,服务端返回订单转为json的字符串. 1.使用maven管理jar包,首先在maven添加使用到的cxf jar包依赖,到CXF官网上找到Maven的依赖内容. 网址如下:http://cxf.apache.org/docs/using-cxf-with-maven.html 我使用的是Tomcat所以引用前两项就可以了 <depen

用JAX-WS在Tomcat中发布WebService

JDK中已经内置了Webservice发布,不过要用Tomcat等Web服务器发布WebService,还需要用第三方Webservice框架.Axis2和CXF是目前最流行的Webservice框架,这两个框架各有优点,不过都属于重量级框架. JAX-WS RI是JAX WebService参考实现.相对于Axis2和CXF,JAX-WS RI是一个轻量级的框架.虽然是个轻量级框架,JAX-WS RI也提供了在Web服务器中发布Webservice的功能.官网地址https://jax-ws.

CXF2.7整合spring发布webservice

---------==========--服务端发布webservice-=============-------- 1.需要的jar包: 2.包结构 3.代码 1.实体类 package cn.qlq.domain; public class User { private String username; private String password; public String getUsername() { return username; } public void setUserna