1、利用jdk web服務api實現,這裏使用基於 SOAP message 的 Web 服務
1.首先創建一個Web services EndPoint:java
package Hello; import javax.jws.WebService; import javax.jws.WebMethod; import javax.xml.ws.Endpoint; @WebService public class Hello { @WebMethod public String hello(String name) { return "Hello, " + name + "\n"; } public static void main(String[] args) { // create and publish an endpoint Hello hello = new Hello(); Endpoint endpoint = Endpoint.publish("http://localhost:8080/hello", hello); } }
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.客戶端程序:
web
1class HelloClient{ 2public static void main(String args[]) { 3 HelloService service = new HelloService(); 4 Hello helloProxy = service.getHelloPort(); 5 String hello = helloProxy.hello("你好"); 6 System.out.println(hello); 7 } 8}
2、使用xfire,我這裏使用的是myeclipse集成的xfire進行測試的
利用xfire開發WebService,能夠有三種方法:
1一種是從javabean 中生成;
2 一種是從wsdl文件中生成;
3 還有一種是本身創建webservice
步驟以下:
用myeclipse創建webservice工程,目錄結構以下:
首先創建webservice接口,
代碼以下:apache
1package com.myeclipse.wsExample; 2//Generated by MyEclipse 3 4public interface IHelloWorldService { 5 6 public String example(String message); 7 8}
接着實現這個藉口:api
1package com.myeclipse.wsExample; 2//Generated by MyEclipse 3 4public class HelloWorldServiceImpl implements IHelloWorldService { 5 6 public String example(String message) { 7 return message; 8 } 9}
修改service.xml 文件,加入如下代碼:
數組
1<service> 2 <name>HelloWorldService</name> 3 <serviceClass> 4 com.myeclipse.wsExample.IHelloWorldService 5 </serviceClass> 6 <implementationClass> 7 com.myeclipse.wsExample.HelloWorldServiceImpl 8 </implementationClass> 9 <style>wrapped</style> 10 <use>literal</use> 11 <scope>application</scope> 12 </service>
把整個項目部署到tomcat服務器中 ,打開瀏覽器,輸入http://localhost:8989/HelloWorld/services/HelloWorldService?wsdl,能夠看到以下:
而後再展開HelloWorldService後面的wsdl能夠看到:
客戶端實現以下:瀏覽器
1package com.myeclipse.wsExample.client; 2 3import java.net.MalformedURLException; 4import java.net.URL; 5 6import org.codehaus.xfire.XFireFactory; 7import org.codehaus.xfire.client.Client; 8import org.codehaus.xfire.client.XFireProxyFactory; 9import org.codehaus.xfire.service.Service; 10import org.codehaus.xfire.service.binding.ObjectServiceFactory; 11 12import com.myeclipse.wsExample.IHelloWorldService; 13 14public class HelloWorldClient { 15public static void main(String[] args) throws MalformedURLException, Exception { 16// TODO Auto-generated method stub 17Service s=new ObjectServiceFactory().create(IHelloWorldService.class); 18XFireProxyFactory xf=new XFireProxyFactory(XFireFactory.newInstance().getXFire()); 19String url="http://localhost:8989/HelloWorld/services/HelloWorldService"; 20 21 try 22 { 23 24 IHelloWorldService hs=(IHelloWorldService) xf.create(s,url); 25 String st=hs.example("zhangjin"); 26 System.out.print(st); 27 } 28 catch(Exception e) 29 { 30 e.printStackTrace(); 31 } 32 } 33 34} 35
這裏再說點題外話,有時候咱們知道一個wsdl地址,好比想用java客戶端引用.net 作得webservice,使用myeclipse引用,可是卻出現沒法經過驗證的錯誤,這時咱們能夠直接在類中引用,步驟以下:tomcat
1public static void main(String[] args) throws MalformedURLException, Exception { 2 // TODO Auto-generated method stub 3 Service s=new ObjectServiceFactory().create(IHelloWorldService.class); 4 XFireProxyFactory xf=new XFireProxyFactory(XFireFactory.newInstance().getXFire()); 5 6 7//遠程調用.net開發的webservice 8Client c=new Client(new URL("http://www.webxml.com.cn/webservices/qqOnlineWebService.asmx?wsdl")); 9 Object[] o=c.invoke("qqCheckOnline", new String[]{"531086641","591284436"}); 10 11//調用.net本機開發的webservice 12Client c1=new Client(new URL("http://localhost/zj/Service.asmx?wsdl")); 13Object[] o1=c1.invoke("HelloWorld",new String[]{}); 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文件,其客戶端調用方法以下:
服務器
1import javax.xml.rpc.Service; 2import javax.xml.rpc.ServiceException; 3import javax.xml.rpc.ServiceFactory; 4 5import java.net.MalformedURLException; 6import java.net.URL; 7import java.rmi.RemoteException; 8 9import javax.xml.namespace.QName; 10 11public class TestHelloWorld { 12 13 14 public static void main(String[] args) throws MalformedURLException, ServiceException, RemoteException { 15 // TODO Auto-generated method stub 16 17 String wsdlUrl ="http://localhost:8989/axis/HelloWorld.jws?wsdl"; 18 String nameSpaceUri ="http://localhost:8989/axis/HelloWorld.jws"; 19 String serviceName = "HelloWorldService"; 20 String portName = "HelloWorld"; 21 22 ServiceFactory serviceFactory = ServiceFactory.newInstance(); 23 Service afService =serviceFactory.createService(new URL(wsdlUrl),new QName(nameSpaceUri, serviceName)); 24 HelloWorldInterface proxy = (HelloWorldInterface)afService.getPort(new QName(nameSpaceUri, portName),HelloWorldInterface.class); 25 System.out.println("return value is "+proxy.getName("john") ) ; 26 27 } 28 29}
4、使用axis2開發webservice(這裏首先感謝李寧老師)
使用axis2 須要先下載 app
axis2-1.4.1-bin.zipeclipse
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類:
1public class HelloWorld{ 2 public String getName(String name) 3 { 4 return "你好 " + name; 5 } 6 public int add(int a,int b) 7 { 8 return a+b; 9 } 10} 11
因爲這兩個方法都是public類型,因此都會發布成webservice。編譯HelloWorld類後,將HelloWorld.class文件放到%tomcat%\webapps\axis2\WEB-INF\pojo目錄中(若是沒有pojo目錄,則創建該目錄),而後打開瀏覽器進行測試:
輸入一下url:
http://localhost:8080/axis2/services/listServices
會列出全部webservice
這是其中的兩個webservice列表,接着,在客戶端進行測試:
首先能夠寫一個封裝類,減小編碼,代碼以下:
1package MZ.GetWebService; 2import javax.xml.namespace.QName; 3 4import org.apache.axis2.AxisFault; 5import org.apache.axis2.addressing.EndpointReference; 6import org.apache.axis2.client.Options; 7import org.apache.axis2.rpc.client.RPCServiceClient; 8 9 10public class GetWSByAxis2 { 11 private static String EndPointUrl; 12 private static String QUrl="http://ws.apache.org/axis2"; 13 private QName opAddEntry; 14 public String WSUrl; 15 public RPCServiceClient setOption() throws AxisFault 16 { 17 RPCServiceClient serviceClient = new RPCServiceClient(); 18 Options options = serviceClient.getOptions(); 19 EndpointReference targetEPR = new EndpointReference(WSUrl); 20 options.setTo(targetEPR); 21 return serviceClient; 22 } 23 24 public QName getQname(String Option){ 25 26 return new QName (QUrl,Option); 27 } 28 //返回String 29 public String getStr(String Option) throws AxisFault 30 { 31 RPCServiceClient serviceClient =this.setOption(); 32 33 opAddEntry =this.getQname(Option); 34 35 String str = (String) serviceClient.invokeBlocking(opAddEntry, 36 new Object[]{}, new Class[]{String.class })[0]; 37 return str; 38 } 39// 返回一維String數組 40 public String[] getArray(String Option) throws AxisFault 41 { 42 RPCServiceClient serviceClient =this.setOption(); 43 44 opAddEntry =this.getQname(Option); 45 46 String[] strArray = (String[]) serviceClient.invokeBlocking(opAddEntry, 47 new Object[]{}, new Class[]{String[].class })[0]; 48 return strArray; 49 } 50 //從WebService中返回一個對象的實例 51 public Object getObject(String Option,Object o) throws AxisFault 52 { 53 RPCServiceClient serviceClient =this.setOption(); 54 QName qname=this.getQname(Option); 55 Object object = serviceClient.invokeBlocking(qname, new Object[]{},new Class[]{o.getClass()})[0]; 56 return object; 57 } 58 59///////////////////////////////////////// 讀者能夠本身封裝數據類型,如int,byte,float等數據類型 60} 61
客戶端調用方法:
2.使用service.xml發佈webservice,這種方式和直接放在pojo目錄中的POJO類不一樣。要想將MyService類發佈成Web Service,須要一個services.xml文件,這個文件須要放在META-INF目錄中,該文件的內容以下:
<service name="HelloWorld"> <description> HelloWorld webservice </description> <parameter name="ServiceClass"> service.HelloWorld </parameter> <messageReceivers> <messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-out" class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" /> <messageReceiver mep="http://www.w3.org/2004/08/wsdl/in-only" class="org.apache.axis2.rpc.receivers.RPCInOnlyMessageReceiver" /> </messageReceivers> </service>
其中<service>元素用於發佈Web Service,一個<service>元素只能發佈一個WebService類,name屬性表示WebService名,以下面的URL能夠得到這個WebService的WSDL內容:
http://localhost:8080/axis2/services/myService?wsdl
除此以外,還有直接能夠在其中制定webservice操做方法:能夠這樣些service.xml文件
1<service name="HelloWorld"> 2 <description> 3 HelloWorld service 4 </description> 5 <parameter name="ServiceClass"> 6 service.HelloWorld 7 </parameter> 8 <operation name="getName"> 9 <messageReceiver class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" /> 10 </operation> 11 <operation name="add"> 12 <messageReceiver 13 class="org.apache.axis2.rpc.receivers.RPCMessageReceiver" /> 14 </operation> 15</service> 16
若是要發佈多個webservice,能夠在文件兩段加上<serviceGroup><service></service>...<service></service></serviceGroup>發佈