使用 CXF 做 webservice 简单例子
  Apache CXF 是一个开放源代码框架,提供了用于方便地构建和开发 Web 服务的可靠基础架构。它允许创建高性能和可扩展的服务,您可以将这样的服务部署在 Tomcat 和基于 Spring 的轻量级容器中,以及部署在更高级的服务器上,例如 Jboss、IBM® WebSphere® 或 BEA WebLogic。
 
      该框架提供了以下功能:
Web 服务标准支持:CXF 支持以下 Web 服务标准:
Java API for XML Web Services (JAX-WS)
SOAP
Web 服务描述语言(Web Services Description Language ,WSDL)
消息传输优化机制(Message Transmission Optimization Mechanism,MTOM)
WS-Basic Profile
WS-Addressing
WS-Policy
WS-ReliableMessaging
WS-Security
前端建模:CXF 提供了前端建模的概念,允许您使用不同的前端 API 来创建 Web 服务。API 允许您使用简单的工厂 Bean 并通过 JAX-WAS 实现来创建 Web 服务。它还允许您创建动态 Web 服务客户端。
工具支持:CXF 提供了用于在 Java Bean、Web 服务和 WSDL 之间进行转换的不同工具。它提供了对 Maven 和 Ant 集成的支持,并无缝地支持 Spring 集成。
RESTful 服务支持:CXF 支持代表性状态传输(Representational State Transfer,RESTful )服务的概念,并支持 Java 平台的 JAX-RS 实现。(本系列的第 2 部分将提供有
关 RESTful 服务的更多信息。)
对不同传输和绑定的支持:CXF 支持不同种类的传输,从 XML 到逗号分隔值 (CSV)。除了支持 SOAP 和 HTTP 协议绑定之外,它还支持 Java Architecture for XML Binding (JAXB) 和 AEGIS 数据绑定。
对非 XML 绑定的支持:CXF 支持非 XML 绑定,例如 JavaScript Object Notation (JSON) 和 Common Object Request Broker Architecture (CORBA)。它还支持 Java 业务集成(Java Business Integration,JBI)体系架构和服务组件体系架构(Service Component Architecture,SCA)。
code first 或者 xml first  : 支持使用code first 或者 xml first 的方式来创建web服务。
       一  借助 annotation 创建独立启动的web 服务。
 
       准备: 新建工程 导入需要的jar 包:
                 
                  依赖的包:
                            commons-logging-1.1.jar
                            geronimo-activation_1.1_spec-1.0-M1.jar (or Sun's Activation jar)
                            geronimo-annotation_1.0_spec-1.1.jar (JSR 250)
                            geronimo-javamail_1.4_spec-1.0-M1.jar (or Sun's JavaMail jar)
                            geronimo-servlet_2.5_spec-1.1-M1.jar (or Sun's Servlet jar)
                            geronimo-ws-metadata_2.0_spec-1.1.1.jar (JSR 181)
                            jaxb-api-2.1.jar
                            jaxb-impl-2.1.6.jar
                            jaxws-api-2.1.jar
                            jetty-6.1.5.jar
                            jetty-util-6.1.5.jar
                            neethi-2.0.jar
                            saaj-api-1.3.jar
                            saaj-impl-1.3.jar
                            stax-api-1.0.1.jar
                            wsdl4j-1.6.1.jar
                            wstx-asl-3.2.1.jar
                            XmlSchema-1.2.jar
                            xml-resolver-1.2.jar     
 
                  spring jar 包, 用来支持xml配置:
                            aopalliance-1.0.jar
                            spring-core-2.0.4.jar
                            spring-beans-2.0.4.jar
                            spring-context-2.0.4.jar
                            spring-web-2.0.4.jar
                 
                  CXF jar包:
                            cxf-2.1.jar
   
         以上jar 包 可从apache下载 apache-cxf-2.1.2.zip, 然后从apache-cxf-2.1.2/lib 目录中获得
 
      1  首先服务点接口。
          package com.demo;
 
          import java.util.List;
          import javax.jws.WebParam;
          import javax.jws.WebService;
         
          @WebService
          public interface HelloWorld {
               String sayHi(@WebParam(name="text")String text);
              String sayHiToUser(User user);
              String[] SayHiToUserList(List<User> userList);
          }
 
    2  编写服务实现
         package com.demo;
        import java.util.LinkedHashMap;
        import java.util.List;
         import java.util.Map;
        import javax.jws.WebService;
 
        @WebService(endpointInterface="com.demo.HelloWorld",serviceName="HelloWorld")
        public class HelloWorldImpl implements HelloWorld {
 
webservice实现                    Map<Integer, User> users = new LinkedHashMap<Integer, User>();
 
                    public String sayHi(String text) {
                                return "Hello " + text;
                   }
 
                   public String sayHiToUser(User user) {
                            users.put(users.size()+1, user);
                            return "Hello "+ Name();
                  }
                  public String[] SayHiToUserList(List<User> userList) {
                             String[] result = new String[userList.size()];
                            int i=0;
                            for(User u:userList){
                                  result[i] = "Hello " + u.getName();
                                  i++;
                            }
                    return result;
                  }
      }
 
  3  编写 webServiceApp.java类来暴露 web服务。
      package com.demo;
      l.ws.Endpoint;
 
      public class webServiceApp {
                public static void main(String[] args) {
                           System.out.println("web service start");
                          HelloWorldImpl implementor= new HelloWorldImpl();
                          String address="localhost:8080/helloWorld";
                           Endpoint.publish(address, implementor);
                          System.out.println("web service started");
                  }
      }
 4  run webServiceApp.java 类来启动服务。 访问 localhost:8080/helloWorld?wsdl  查看是否显示
    wsdl。
 
 5  编写客户端访问服务。
    package com.demo;
    import java.util.ArrayList;
    import java.util.List;
    import f.jaxws.JaxWsProxyFactoryBean;
    import t.support.ClassPathXmlApplicationContext;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。