webservice的应用已经愈来愈普遍了,下面介绍几种在Java体系中开发webservice的方式,至关于作个记录。html
1.Axis2方式java
Axis是apache下一个开源的webservice开发组件,出现的算是比较早了,也比较成熟。这里主要介绍Axis+eclipse开发webservice,固然不用eclipse也能够开发和发布webservice,只是用eclipse会比较方便。web
(1)下载eclipse的Java EE版本spring
http://www.eclipse.org/downloads/apache
(2)下载axis2api
http://axis.apache.org/axis2/java/core/download.cgi数组
(3)下载eclipse的axis2插件浏览器
Axis2_Codegen_Wizardtomcat
Axis2_Service_Archiver服务器
http://axis.apache.org/axis2/java/core/tools/index.html
推荐使用1.3的版本
(4)eclipse安装axis2插件
1)在任意目录下新建一个Axis2文件夹,在该文件夹下新建eclipse目录,在eclipse目录中新建plugins目录和features目录,例如:D:\programSoftware\eclipse-SVN\Axis2\eclipse;
2)把下载的axis2插件解压,并把解压的文件放到新建的eclipse的plugins目录下;
3)在%eclipse_home%的目录下新建links目录,并在links目录下新建axis2.link文件,内容为:path=D:\programSoftware\eclipse-SVN\Axis2;
4)重启eclipse,点击·file-new-other,若是看到Axis2 Wizards,则代表插件安装成功。
(5)安装axis2
下载Axis2的WAR Distribution并解压,把axis2.war包放置到%TOMCAT_HOME%/webapps下,启动tomcat,访问http://localhost:port/axis2,Axis2安装成功。
(6)使用eclipse新建web工程,建立一个普通java类,至少包含一个方法。
(7)发布webservice
1)点击eclipse的File-New-other,打开Axis2 Wizards,选择Axis2 Service Archiver,而后Next;
2)选择Class File Location,也就是类文件存放路径,注意:只选到classes目录,不要包括包文件夹,而后Next;
3)选择Skip WSDL,而后Next
4)一路Next到Select the Service XML file to be included in the Service archive,勾选Generate theservice xml automatically;
5)Service Name-填写你的service名称,Class Name-填写类名称,要包括包名,而后点击load,而后点击Finish,这时webservice就发布成功了;
6)而后到%TOMCAT_HOME%/webapps/axis2/WEB-INF/services 看看是否多了一个.aar的文件;
7)访问http://localhost:8085/axis2/services/类名?wsdl 就可看到生成的wsdl文件了。
注意:以上的方式是发布到axis2.war包中,你也能够把生成.aar文件copy到你的实际应用中,同时,你也可使用eclipse的create webservice功能发布你的webservice,选择axis2生成你的webservice,这样webservice就会部署到你的应用中了。
2.Apche CXF方式
CXF开发webservice也是比较方便和简单的,它和spring的集成能够说是很是地好。举一个CXF开发webservice的例子吧。
1)在eclipse中新建一个web工程,导入依赖包,如图:
2)编写一个接口,如:
public String test(@WebParam(name="value", targetNamespace = "http://service.cxf.zcl.com/", mode = WebParam.Mode.IN)String value);
注意:CXF开发的webservice,接口中的方法的参数必定要以这种方式,不然客户端调用的时候CXF服务端会接收不到参数的值,name:参数名称,可不写(建议写上),targetNamespace:命名空间,必定要填写上,默认是包名反过来的顺序,mode:参数类型,IN表示输入。
3)编写一个实现类,实现接口的方法;
4)和spring的集成,编写一个bean文件,如:cxf-beans.xml,内容以下:
- <?xml version="1.0" encoding="UTF-8" ?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:jaxws="http://cxf.apache.org/jaxws"
- xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
- http://cxf.apache.org/jaxws http://cxf.apache.org/schemas/jaxws.xsd">
- <import resource="classpath:META-INF/cxf/cxf.xml" />
- <import resource="classpath:META-INF/cxf/cxf-extension-soap.xml" />
- <import resource="classpath:META-INF/cxf/cxf-servlet.xml" />
- <jaxws:endpoint id="vote" implementor="com.zcl.cxf.service.VoteImpl" address="/Vote" />
- </beans>
这个文件比较容易理解,就不解释了。
5)配置CXFServlet
在web.xml文件中配置CXFServlet,加载cxf-beans.xml文件,内容以下:
- <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
- xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
- id="WebApp_ID" version="2.5">
- <context-param>
- <param-name>contextConfigLocation</param-name>
- <param-value>WEB-INF/cxf-beans.xml</param-value>
- </context-param>
- <listener>
- <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
- </listener>
- <servlet>
- <servlet-name>cxf</servlet-name>
- <servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-class>
- <load-on-startup>1</load-on-startup>
- </servlet>
- <servlet-mapping>
- <servlet-name>cxf</servlet-name>
- <url-pattern>/services/*</url-pattern>
- </servlet-mapping>
- </web-app>
把工程部署到中间件,如tomcat,就能够访问该webservice了。
3.JDK开发webservice方式
1)编写一个Java类,以下:
- package demo;
- import javax.jws.WebParam;
- import javax.jws.WebService;
- import javax.xml.ws.Endpoint;
- @WebService
- public class JdkWebService {
- public String doSomething(@WebParam(name="value", targetNamespace = "http://demo/", mode = WebParam.Mode.IN)String value) {
- return "Just do it," + value + "!";
- }
- public static void main(String[] args) {
- Endpoint.publish("http://localhost:8080/jdkwsdemo/demo.JdkWebService", new JdkWebService());
- }
- }
2)运行该java类,在浏览器上就能够访问该webservice了。
注意:开发web工程的时候,这种方法不太友好。咱们能够编写一个servlet类,在servlet类的初始化方法中发布webservice,这样咱们的中间件服务器启动的时候就会帮咱们自动webservice了。
4. xfire方式
1.新建一个java web project命名为TestWebService,将xfire相关的jar包添加到lib目录中,写接口类和实现类
- package com.lamp.service;
- public interface MessageService {
- public String getName(String name);
- }
- package com.lamp.service.impl;
- import com.lamp.service.MessageService;
- public class MessageServiceImpl implements MessageService {
- public String getName(String name) {
- return "hellow " + name + ", welcome to WebService world";
- }
- }
- <?xml version="1.0" encoding="UTF-8"?>
- <beans xmlns="http://xfire.codehaus.org/config/1.0">
- <service>
- <name>MessageService</name>
- <serviceClass>com.lamp.service.MessageService</serviceClass>
- <implementationClass>com.lamp.service.impl.MessageServiceImpl</implementationClass>
- </service>
- </beans>
最后在web.xml中配置xfire的servlet
- <servlet>
- <servlet-name>XFireServlet</servlet-name>
- <servlet-class>
- org.codehaus.xfire.transport.http.XFireConfigurableServlet
- </servlet-class>
- </servlet>
- <servlet-mapping>
- <servlet-name>XFireServlet</servlet-name>
- <url-pattern>/servlet/XFireServlet/*</url-pattern>
- </servlet-mapping>
- <servlet-mapping>
- <servlet-name>XFireServlet</servlet-name>
- <url-pattern>/services/*</url-pattern>
- </servlet-mapping>
项目部署后在浏览器中经过http://localhost:8080/TestWebService/services访问看到远程访问的接口,并获得wsdl为http://localhost:8080/TestWebService/services/MessageService?wsdl
这样服务器端开发完毕,如今开始客户端的开发
新建一个java project也将xfire相关的jar引入,我用ant在客户端生成代理对象,在项目路径下新建build.xml,代码为
- <?xml version="1.0" encoding="UTF-8"?>
- <project name="WebService" basedir="." default="gen-webservice">
- <property file="build.properties">
- </property>
- <path id="project-classpath">
- <fileset dir="${lib.dir}">
- <include name="**/*.jar" />
- </fileset>
- </path>
- <target name="gen-webservice">
- <taskdef name="wsgen" classname="org.codehaus.xfire.gen.WsGenTask" classpathref="project-classpath" />
- <wsgen outputDirectory="${src.dir}"
- wsdl="${wsdl.dir}" package="com.lamp.ws.client" overwrite="true"/>
- </target>
- </project>
其引入的build.properties文件也在项目路径下
src.dir=${basedir}/src
lib.dir=F:/WebService/xfire-1.2.6/lib
wsdl.dir=http://localhost:8080/TestWebService/services/MessageService?wsdl
其中lib.jar为我存放xfire的路径,运行ant获得代理对象
编写一个测试类
- package com.lamp.test;
- import com.lamp.ws.client.MessageServiceClient;
- import com.lamp.ws.client.MessageServicePortType;
- public class TestGetName {
- public static void main(String[] args) {
- MessageServiceClient msg = new MessageServiceClient();
- MessageServicePortType portType = msg.getMessageServiceHttpPort();
- String result = portType.getName("张三");
- System.out.println(result);
- }
- }
运行在控制台看到了hellow 张三, welcome to WebService world至此一个简单的WebService开发完毕
------------------------------------------------------------------------------------------------
webservice的应用已经愈来愈普遍了,下面介绍几种在Java体系中开发webservice的方式,至关于作个记录。
如今webservice加xml技术已经逐渐成熟,但要真正要用起来还需时日!!
因为毕业设计缘故,我看了不少关于webservice方面的知识,今天和你们一块儿来研究研究webservice的各类使用方法。
1、利用jdk web服务api实现,这里使用基于 SOAP message 的 Web 服务
1.首先创建一个Web services EndPoint:




















2.使用 apt 编译 Hello.java(例:apt -d [存放编译后的文件目录] Hello.java ) ,会生成 jaws目录
3.使用java Hello.Hello运行,而后将浏览器指向http://localhost:8080/hello?wsdl就会出现下列显示
4.使用wsimport 生成客户端
使用以下:wsimport -p . -keep http://localhost:8080/hello?wsdl
这时,会在当前目录中生成以下文件:
5.客户端程序:

2

3

4

5

6

7

8

9

以上方法还稍显繁琐,还有更加简单的方法
2、使用xfire,我这里使用的是myeclipse集成的xfire进行测试的
利用xfire开发WebService,能够有三种方法:
1一种是从javabean 中生成;
2 一种是从wsdl文件中生成;
3 还有一种是本身创建webservice
步骤以下:
用myeclipse创建webservice工程,目录结构以下:
首先创建webservice接口,
代码以下:

2

3

4

5

6

7

8

接着实现这个借口:

2

3

4

5

6

7

8

9

10

修改service.xml 文件,加入如下代码:

2

3

4

5

6

7

8

9

10

11

12

把整个项目部署到tomcat服务器中 ,打开浏览器,输入http://localhost:8989/HelloWorld/services/HelloWorldService?wsdl,能够看到以下:
而后再展开HelloWorldService后面的wsdl能够看到:
客户端实现以下:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

这里再说点题外话,有时候咱们知道一个wsdl地址,好比想用java客户端引用.net 作得webservice,使用myeclipse引用,可是却出现没法经过验证的错误,这时咱们能够直接在类中引用,步骤以下:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

3、使用axis1.4调用webservice方法
前提条件:下载axis1.4包和tomcat服务器 ,并将axis文件夹复制到tomcat服务器的webapp文件夹中
这里我就说一下最简单的方法:
首先创建一个任意的java类(例如:HelloWorld.java),复制到axis文件夹下,将其扩展名改成jws,而后从新启动tomcat,在浏览器中输入http://localhost:8989/axis/HelloWorld.jws?wsdl,就会获得一个wsdl文件,其客户端调用方法以下:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

4、使用axis2开发webservice(这里首先感谢李宁老师)
使用axis2 须要先下载
axis2-1.4.1-bin.zip
axis2-1.4.1-war.zip
http://ws.apache.org/axis2/
同理,也须要将axis2复制到webapp目录中
在axis2中部署webservice有两种方法,
第一种是pojo方式,这种方式比较简单,可是有一些限制,例如部署的类不能加上包名
第二种方式是利用xml发布webservice,这种方法比较灵活,不须要限制类的声明
下面分别说明使用方法:
1.pojo方式:在Axis2中不须要进行任何的配置,就能够直接将一个简单的POJO发布成WebService。其中POJO中全部的public方法将被发布成WebService方法。先实现一个pojo类:

2

3

4

5

6

7

8

9

10

11

因为这两个方法都是public类型,因此都会发布成webservice。编译HelloWorld类后,将HelloWorld.class文件放到%tomcat%\webapps\axis2\WEB-INF\pojo目录中(若是没有pojo目录,则创建该目录),而后打开浏览器进行测试:
输入一下url:
http://localhost:8080/axis2/services/listServices
会列出全部webservice
这是其中的两个webservice列表,接着,在客户端进行测试:
首先能够写一个封装类,减小编码,代码以下:

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

客户端调用方法:







2.使用service.xml发布webservice,这种方式和直接放在pojo目录中的POJO类不一样。要想将MyService类发布成Web Service,须要一个services.xml文件,这个文件须要放在META-INF目录中,该文件的内容以下:















其中<service>元素用于发布Web Service,一个<service>元素只能发布一个WebService类,name属性表示WebService名,以下面的URL能够得到这个WebService的WSDL内容:
http://localhost:8080/axis2/services/myService?wsdl
除此以外,还有直接能够在其中制定webservice操做方法:能够这样些service.xml文件

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

若是要发布多个webservice,能够在文件两段加上<serviceGroup><service></service>...<service></service></serviceGroup>发布