webservice學習

注:紅色部分爲我添加的。
axis 支持三種 web service 的部署和開發,分別爲:
1.Dynamic Invocation Interface ( DII)
2.Stubs
方式

使用dii的方式

1. 編寫服務端程序HelloService
public class HelloService{
public String getName(String name)
{
return "Welcome to Axis, "+name;
}
}

2.
將源碼拷貝到AXIS_HOME 下,重命名爲 HelloService.jws
3.
訪問鏈接http://localhost:8080/axis/HelloService.jws?wsdl ,頁面顯示axis 自動生成的wsdl( 而且在axis\WEB-INF\jwsClasses 生成HelloService.class 類文件)
4.
編寫訪問服務的客戶端 HelloClient.java, 編譯, 執行, 在命令提示行下會看到 "return value is Welcome to Axis ,fengshan"
public class HelloClient {
   public static void main(String[] args) {
     try {
      String endpoint = "http://localhost:8080/axis/HelloService.jws";
      Service service = new Service();
      Call call = null;
      call = (Call) service.createCall();
      call.setOperationName(new QName(
          "http://localhost:8080/axis/HelloService.jws", "getName"));
      call.setTargetEndpointAddress(new java.net.URL(endpoint));
      String ret = (String) call.invoke(new Object[] { "fengshan" });
      System.out.println("return value is " + ret);
    } catch (Exception ex) {
      ex.printStackTrace();
    }
  }
}
總結:dii方式比較簡單,服務器端暴露一個類,客戶端經過固定的方式(套路來訪問服務器提供的服務)
服務器:寫一個類,裏面有一個業務方法,而後將後綴名字從java改爲jws
客戶端:1.構造鏈接地址:http://localhost:8080/axis/HelloService.jws (ip+路徑+類名.jws)
      2.構造vservice對象,掉用service對象的createCall()方法返回call對象
      3.調用call對象的etOperationName()方法設置訪問webservice資源的參數
      4.調用call對象的invoke()方法,而且傳遞對象數組,字符串類型,(經過wsdl能夠觀察出requestresponse的參數,根據這些表述,來設置請求參數和接受返回數據)
 
 

使用Stubs方式

1.服務器端仍然使用HelloService.java,編譯後將他放在axis\WEB-INF\classes
2.編寫deploy.wsdd文件,聲明服務器端須要發佈的webservice的名字,和她的方法(放在web-inf目錄下)
deploy.wsdd 內容 :
< deployment xmlns ="http://xml.apache.org/axis/wsdd/"
         xmlns:java ="http://xml.apache.org/axis/wsdd/providers/java" >
< service name ="HelloService" provider ="java:RPC" >
     < parameter name ="className"    
             value ="HelloService" />
     < parameter name ="allowedMethods" value ="*" />    <!---這裏也能夠填寫須要暴露的方法的名字->
</ service >
</ deployment >    
 
3.切換到deploy.wsdd所在目錄,運行java org.apache.axis.client.AdminClient deploy.wsdd,若是部署成功,會輸出<Admin>Done processing</Admin>信息。能夠點擊http://localhost:8080/axis瀏覽器中List來查看所發佈的服務。
4. 接下來客戶端測試該服務。
首先,在環境變量中設置 CLASSPATH ,加入如下 jar %AXIS_LIB%\axis.jar;
%AXIS_LIB%\axis-ant.jar;
%AXIS_LIB%\commons-discovery.jar;
%AXIS_LIB%\commons-logging.jar;
%AXIS_LIB%\jaxrpc.jar;
%AXIS_LIB%\saaj.jar;
%AXIS_LIB%\log4j- 1.2.8 .jar;
%AXIS_LIB%\wsdl4j.jar
能夠經過如下命令查看是否設置好了 CLASSPATH Echo %CLASSPATH%
Axis
提供了實現WSDL2Java 的命令行工具org.apache.axis.wsdl.WSDL2Java ,利用這個工具能夠從WSDL 地址處生成Java 代碼。命令以下:( axis 目錄下)
java org.apache.axis.wsdl.WSDL2Java -Nhttp://localhost:8080/axis/services/HelloService=com http://localhost:8080/axis/services/HelloService?wsdl
會在com (由上述命令行中參數設定)包下生成HelloService.java HelloServiceService.java HelloServiceServiceLocator.java HelloServiceSoapBindingStub.java 四個文件。

5.
編寫測試類( axis 目錄下)
public class HelloClient
{
     public static void main(String[] args)
    {
     try
     {    
        com.HelloServiceServiceLocator locator= new com.HelloServiceServiceLocator();
        com.HelloService service=locator.getHelloService();
        System.out.println(service.getName( "fengshan"));
     }
     catch(Exception e)
     {
         System.err.println( "Execution failed.Exception:"+e);
     }
    }
}
總結:Stubs方式主要是服務器端使用deploy.wsdd 文件,寫好須要暴露的webservice的名字和其中的方法,使用 java org.apache.axis.client.AdminClient deploy.wsdd 將她部署在服務器上供外界調用,而外界使用 java org.apache.axis.wsdl.WSDL2Java -Nhttp://localhost:8080/axis/services/HelloService=com http://localhost:8080/axis/services/HelloService?wsdl 將遠端的webservice映射成本地類,供本身使用
 
使用步驟:
1.    在得到自動映射的4個類之後,new一個 loctor對象,這個對象實現了 一個接口(HelloServiceService ),調用接口種的方法getHelloService()得到一個service對象,而後用這個對象調用webservice暴露的方法會獲得一個返回值(String).
咱們本身也能夠簡單寫一個客戶端來調用:
public class HelloWorldClient1 {
       public static void main(String[] args) {
              try {
                     Service service = new Service();
                     String Url = "http://localhost:8080/axis/services/HelloService";
                     Call call = (Call) service.createCall();
                     call.setTargetEndpointAddress(Url);
                     call.setOperationName(new QName(Url, "getName"));
                     String result = (String) call.invoke(new Object[] { "winwin" });
                     System.out.println(result);
              } catch (ServiceException e) {
                     e.printStackTrace();
              } catch (RemoteException e) {
                     e.printStackTrace();
              }
       }
}
其實上面四個自動生成的java文件也就是像以上這個客戶端這樣來調用的。能夠對照看看。