`

基于jdk规范的webservice

    博客分类:
  • java
 
阅读更多

      最近在项目中使用webservice连接调用其他系统的接口,自己学习了一下webservice。demo如下

1.基于jdk1.6以上jdk自带的webservice,我们在jdk安装目录下的bin目录下可以看到wsimport.exe的文件,这个文件就是用于webservice的,在命令行输入wsimport我们会看到



 下面是webservice接口

@WebService
public interface WebServiceServer {
	
	public void sayService();
	
	public void sayService(String name);
	
}

 webservice服务端实现类

@WebService
//@SOAPBinding(style=Style.RPC)
public class WebServiceServerImpl implements WebServiceServer {

	@Override
	@WebMethod(exclude=true)
	public void sayService() {
		System.out.println("此方法不开放");
	}

	@Override
	public void sayService(String name) {
		System.out.println("Hi, I'm " + name);
	}

}

 发布接口

public class Server {
	private final static  String ADDR = "http://localhost:8888/testWebService/helloWorld";
	
	public static void main(String[] args) {
		WebServiceServer server = new WebServiceServerImpl();
		Endpoint.publish(ADDR, server);
	}
}

 此处localhost表示本机,如果在不同机器上使用改为对应的ip地址

发布后访问地址



 点击右边的URL?wsdl就可以看到对应的webservice报文信息了



 接着我们可以在命令行使用命令生成客户端代码了

wsimport -s . -p com.share.server  http://localhost:8888/testWebService/helloWorld?wsdl

生成代码



 将.class文件删除即可:

接着客户端代码

public class WebClient {

	public static void main(String[] args) {
		WebServiceServerImpl ws = new WebServiceServerImplService().getWebServiceServerImplPort();
		ws.sayName("张三");
	}
}

 输出 Hi, I'm 张三  则调用成功

 

2.基于cxf的

首先我们需要下载Apache-cxf,然后解压配置环境变量,接着查看里面的示例,我们从lib包中选择

asm-3.3.1.jar

cxf-2.6.2.jar

geronimo-servlet_2.5_spec-1.1.2.jar

neethi-3.0.2.jar

wsdl4j-1.6.2.jar

xmlschema-core-2.0.3.jar

jetty-continuation-7.5.4.v20111024.jar

jetty-http-7.5.4.v20111024.jar

jetty-io-7.5.4.v20111024.jar

jetty-security-7.5.4.v20111024.jar

jetty-server-7.5.4.v20111024.jar

jetty-util-7.5.4.v20111024.jar

下面直接上代码

接口

@WebService
public interface IBirthAddr {
	public String getBirthAddr1(String addr);
}

 实现类

@WebService(endpointInterface="com.share.server_cxf.IBirthAddr")
public class BirthAddrImpl implements IBirthAddr {

	@Override
	public String getBirthAddr1(String addr) {
		return "我出生于:" + addr;
	}

}

 发布类

public class Publish {
	
	public static void main(String[] args) {
		testJaxwsServerFactoryBean();
	}
public static void testJaxwsServerFactoryBean() {
		// 1.创建ServerFactoryBean的对象,用于发布服务
		JaxWsServerFactoryBean server = new JaxWsServerFactoryBean();
		// 2.设置服务发布地址
		server.setAddress("http://192.168.1.100:9999/ws_cxf1");
		// 3.设置服务发布的接口
		server.setServiceClass(IBirthAddr.class);
		// 4.设置服务的发布对象
		server.setServiceBean(new BirthAddrImpl());
		// 5.使用create方法发布服务
		server.create();
		System.out.println("cxf");
		
	}
}

 另外你导入cxf文件夹下的lib的全部包注意

需要添加

Stax2-api-3.1.4.jar  woodstox-core-asl-4.4.1.jar否则报错

删除:cxf-services-ws-discovery-api-3.1.4.jar
cxf-services-ws-discovery-service-3.1.4.jar
cxf-services-wsn-api-3.1.4.jar
cxf-services-wsn-core-3.1.4.jar

 

四个包

否则报错

客户端生成代码命令

wsdl2java -d . -p com.share.server http://192.168.1.100:9999/ws_cxf1?wsdl

-d表示当前目录 -d 与 . 之间有空格 

-p 指定包名 

注意jdk与cxf的版本问题,否则wsdl2java命令不能使用

 

生成的文件如下:

客户端调用代码

public class Call {
	public static void main(String[] args) {
		testClientProxyFactoryBean();
	}
	
	public static void testClientProxyFactoryBean() {
//  	1.创建ClientProxyFactoryBean的对象,用于接收服务
		JaxWsProxyFactoryBean bean = new JaxWsProxyFactoryBean();
//  	2.设置服务的发布地址,表示去哪里过去服务
  	 	bean.setAddress("http://192.168.1.3:9998/ws_cxf1");
//  	3.设置服务的发布接口,使用本地的代理接口
  	 	bean.setServiceClass(IBirthAddr.class);
//  	4.通过create方法返回接口代理实例
  	 	IBirthAddr ws = (IBirthAddr) bean.create();
//  	5.调用远程方法
  	 	System.out.println(ws.getBirthAddr1("上海"));
	}
}

 
 打印 :我出生于:上海成功

  • 大小: 30.5 KB
  • 大小: 24 KB
  • 大小: 39.2 KB
  • 大小: 28.2 KB
  • 大小: 4.9 KB
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics