<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-72  評論-20  文章-0  trackbacks-1
    本文將介紹如何使用Tomcat5.0和Apache Axis2開發、部署及測試一個簡單的Web Service應用。
    author: ZJ
     
    1工作環境
    Eclipse
    http://ws.apache.org/axis2/download/1_0/download.cgi頁面下,下載AXIS2的Binary Distribution url: http://apache.justdn.org/ws/axis2/1_0/axis2-std-1.0-bin.zip和war Distribution url: http://apache.justdn.org/ws/axis2/1_0/axis2-1.0-docs.zip。把這兩個文件解壓,比如解壓縮的后得目錄為C:\axis2-std-1.0-bin和C:\axis2.war。
    在Eclipse下通過菜單window—preferences…--Java—Build Path—User Libraries 新建一個user library,比如名字就叫axis2把C:\axis2-std-1.0-bin\lib下的所有jar文件包含進來。把axis2.war拷貝到%TOMCAT-HOME%/webapps下面。
     
    2.檢驗安裝
    在Eclipse下啟動Tomcat,在地址欄內輸入http://localhost:8080/axis2/。
    點擊Validate,將到達 Axis2 Happiness Page。
    3.WebService中的HelloWorld
    1)新建一個動態web工程,取名ZZaxis,右鍵點擊項目名,選擇Properties-Java Build Path-Add Library-User Library-axis2。
     
    2)新建package sample,建立HelloWorld.java,代碼如下。
    HelloWorld.java
    import org.apache.axiom.om.OMAbstractFactory;
    import org.apache.axiom.om.OMElement;
    import org.apache.axiom.om.OMFactory;
    import org.apache.axiom.om.OMNamespace;
     
    public class HelloWorld {
           public OMElement sayHello(OMElement in){
                  String name=in.getText();
                  String info=name+"HelloWorld!";
                  OMFactory fac=OMAbstractFactory.getOMFactory();
                  OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
                  OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
                  resp.setText(info);
                  return resp;
           }
    }
     
    3)在WebContent\META-INF\建立services.xml,代碼如下。
    services.xml
    <?xml version="1.0" encoding="UTF-8"?>
    <service name="HelloWorld">
    <description>
      This is a sample Web Service.
    </description>
    <parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
    <operation name="sayHello">
      <messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
    </operation>
    </service>
     
    4)將目錄sample和目錄META-INF組織如下(新建目錄example)。
    +-example
    |-------- +-sample
        |------- HelloWorld.class
    |---------+-META-INF
           |------- services.xml
     
    5)打包生成aar文件。
    在命令符環境下,將當前目錄轉到example。
    jar cvf HelloWorld.aar . //注意最后一個點,在當前目錄下生成HelloWorld.aar。
     
    6)在Eclipse中啟動Tomcat,在地址欄下鍵入http://localhost:8080/axis2/。選擇Administration,輸入用戶名admin,密碼axis2。選擇左側工具欄Tools- Upload Service,上傳之前打包的HelloWorld.aar。該文件將在<CATALINA_HOME>/webapps/axis2\WEB-INF\services目錄下。
     
    7)編寫客戶端檢驗代碼。新建Java Project,取名為ZZaxisClient。右鍵點擊項目名,選擇Properties-Java Build Path-Add Library-User Library-axis2。
     
    8)新建package example.client。建立TestClient.java,代碼如下。
    TestClient.java
    package example.client;
     
    import org.apache.axiom.om.OMAbstractFactory;
    import org.apache.axiom.om.OMElement;
    import org.apache.axiom.om.OMFactory;
    import org.apache.axiom.om.OMNamespace;
    import org.apache.axis2.addressing.EndpointReference;
    import org.apache.axis2.client.Options;
    import org.apache.axis2.client.ServiceClient;
     
    public class TestClient {
           private static EndpointReference targetEPR=new EndpointReference
             ("http://localhost:8080/axis2/services/HelloWorld");
           public static OMElement getSayHelloOMElement(){
                  OMFactory fac=OMAbstractFactory.getOMFactory();
                  OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
                  OMElement method=fac.createOMElement("sayHello",omNs);
                  method.setText("ZJ");
                  return method;
           }
           public static void main(String[] args){
                  try{
                         Options options=new Options();
                         options.setTo(targetEPR);
                         ServiceClient sender=new ServiceClient();
                         sender.setOptions(options);
                         OMElement sayHello=TestClient.getSayHelloOMElement();
                         OMElement result=sender.sendReceive(sayHello);
                         System.out.println(result);
                  }
                  catch(Exception axisFault){
                         axisFault.printStackTrace();
                  }
           }
    }
     
    9)測試,run TestClient.java as Java Application。結果:
    <hw:sayHelloResponse xmlns:hw="http://helloworld.com/"
    xmlns:tns="http://ws.apache.org/axis2">
    ZJHelloWorld!
    </hw:sayHelloResponse>
     
    4.后續
    詳細介紹client和server端代碼。
    代碼實例:

    1.HelloWorld做了些什么?
    HelloWorld功能非常簡單,在客戶端輸入你的姓名,本例中為ZJ。參數傳遞到服務器端后,經過處理將返回name+"HelloWorld!",本例中為ZJ HelloWorld!
     
    2.服務器端文件HelloWorld.java
    HelloWorld.java
    package sample;
     
    import org.apache.axiom.om.OMAbstractFactory;
    import org.apache.axiom.om.OMElement;
    import org.apache.axiom.om.OMFactory;
    import org.apache.axiom.om.OMNamespace;
     
    public class HelloWorld {
        //讀取client端getSayHelloOMElement()方法傳遞的參數in。
           public OMElement sayHello(OMElement in){
            //將in轉換為String。
                  String name=in.getText();
                  String info=name+"HelloWorld!";
            //創建response SOAP包。
                  OMFactory fac=OMAbstractFactory.getOMFactory();
            // OMNamespace指定此SOAP文檔名稱空間。
                  OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
            //創建元素sayHello,并指定其在omNs指代的名稱空間中。
                  OMElement resp=fac.createOMElement("sayHelloResponse",omNs);
            //指定元素的文本內容。
                  resp.setText(info);
                  return resp;
           }
    }
     
    3.services.xml部署文件
    services.xml
    <?xml version="1.0" encoding="UTF-8"?>
    //下面定義服務名
    <service name="HelloWorld">
    <description>
      This is a sample Web Service.
    </description>
    // ServiceClass指定Java Class的位置,即實現服務的類。
    <parameter name="ServiceClass" locked="false">sample.HelloWorld</parameter>
    // operation 與Java Class中方法名對應。
    <operation name="sayHello">
    // messageReceiver看下文注解。
      <messageReceiver class="org.apache.axis2.receivers.RawXMLINOutMessageReceiver"/>
    </operation>
    </service>
     
    注解:消息交換模式。
    目前Axis2支持三種模式:In-Only、Robust-In和In-Out。In-Only消息交換模式只有SOAP請求,而不需要應答;Robust-In消息交換模式發送SOAP請求,只有在出錯的情況下才返回應答;In-Out消息交換模式總是存在SOAP請求和應答。本例使用In-Out模式。
     
    4.客戶端文件TestClient.java
    TestClient.java
    package example.client;
     
    import org.apache.axiom.om.OMAbstractFactory;
    import org.apache.axiom.om.OMElement;
    import org.apache.axiom.om.OMFactory;
    import org.apache.axiom.om.OMNamespace;
    import org.apache.axis2.addressing.EndpointReference;
    import org.apache.axis2.client.Options;
    import org.apache.axis2.client.ServiceClient;
     
    public class TestClient {
        // targetEPR指定打包的Service(.aar文件)在容器中的物理位置。
           private static EndpointReference targetEPR=new EndpointReference
             ("http://localhost:8080/axis2/services/HelloWorld");
           public static OMElement getSayHelloOMElement(){
            //創建request SOAP包。
                  OMFactory fac=OMAbstractFactory.getOMFactory();
            // OMNamespace指定此SOAP文檔名稱空間。
                  OMNamespace omNs=fac.createOMNamespace("http://helloworld.com/","hw");
            //創建元素sayHello,并指定其在omNs指代的名稱空間中。
                  OMElement method=fac.createOMElement("sayHello",omNs);
            //指定元素的文本內容。
                  method.setText("ZJ");
                  return method;
           }
           public static void main(String[] args){
                  try{
                         Options options=new Options();
                         options.setTo(targetEPR);
                         ServiceClient sender=new ServiceClient();
                         sender.setOptions(options);
                         OMElement sayHello=TestClient.getSayHelloOMElement();
                //發出request SOAP,
    //同時將得到的遠端由sayHello方法返回的信息保存到result。
    //通過services.xml能準確找到sayHello方法所在的文件。
                         OMElement result=sender.sendReceive(sayHello);
                  }
                  catch(Exception axisFault){
                         axisFault.printStackTrace();
                  }
           }
    }
     
    5.Axis2簡介
    Apache Axis2 是Axis的后續版本,是新一代的SOAP引擎。Axis2的主要特點有:
    1)采用名為 AXIOM(AXIs Object Model)的新核心 XML 處理模型,利用新的XML解析器提供的靈活性按需構造對象模型。
     
    2)支持不同的消息交換模式。目前Axis2支持三種模式:In-Only、Robust-In和In-Out。In-Only消息交換模式只有SOAP請求,而不需要應答;Robust-In消息交換模式發送SOAP請求,只有在出錯的情況下才返回應答;In-Out消息交換模式總是存在SOAP請求和應答。
     
    3)提供阻塞和非阻塞客戶端 API。
     
    4)支持內置的 Web服務尋址 (WS-Addressing) 。
     
    5)靈活的數據綁定,可以選擇直接使用 AXIOM,使用與原來的 Axis 相似的簡單數據綁定方法,或使用 XMLBeans、JiBX 或 JAXB 2.0 等專用數據綁定框架。
     
    6)新的部署模型,支持熱部署。
     
    7)支持HTTP,SMTP,JMS,TCP傳輸協議。
     
    8)支持REST (Representational State Transfer)。
     
    6.Axis2 支持的規范包括:
    -SOAP 1.1 and 1.2
    -Message Transmission Optimization Mechanism (MTOM), XML Optimized Packaging (XOP) and SOAP with Attachments
    -WSDL 1.1, including both SOAP and HTTP bindings
    -WS-Addressing (submission and final)
    -WS-Policy
    -SAAJ 1.1
    有關Axis2更加詳細的介紹,可以訪問Axis2網站http://ws.apache.org/axis2/


    posted on 2007-08-19 04:52 前方的路 閱讀(2493) 評論(0)  編輯  收藏 所屬分類: Java技術
    主站蜘蛛池模板: 全免费A级毛片免费看网站| 久久久高清日本道免费观看| 9久9久女女免费精品视频在线观看 | 亚洲视频免费在线看| 久久免费精彩视频| 久久久亚洲精品国产| 久久国产精品萌白酱免费| 国产亚洲人成网站在线观看不卡| 黄色视屏在线免费播放| 精品国产人成亚洲区| 中文字幕av免费专区| 亚洲国产成人一区二区三区| 成全视频高清免费观看电视剧| 亚洲色欲久久久综合网| 久久免费视频网站| 亚洲综合视频在线观看| av免费不卡国产观看| 亚洲欧美国产国产一区二区三区| 国产成人啪精品视频免费网| 日本激情猛烈在线看免费观看| 不卡精品国产_亚洲人成在线| 91精品成人免费国产| 久久亚洲精品无码AV红樱桃| 中文字幕免费视频| 国内精品久久久久影院亚洲| 四虎永久在线免费观看| 99久久免费国产特黄| 97se亚洲综合在线| 全免费A级毛片免费看网站| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 亚洲AV成人一区二区三区在线看| 免费无码一区二区三区蜜桃大| 无人视频免费观看免费视频 | 搡女人免费免费视频观看| 日韩精品亚洲人成在线观看 | 激情无码亚洲一区二区三区| 国内精品久久久久久久亚洲| 91大神免费观看| 猫咪免费人成网站在线观看入口| 丁香五月亚洲综合深深爱| 91精品免费国产高清在线|