当前位置: 代码迷 >> Web前端 >> XFire 运用入门
  详细解决方案

XFire 运用入门

热度:541   发布时间:2012-09-23 10:28:11.0
XFire 使用入门
 
一.  介绍

XFire是下一代的java SOAP框架。XFire提供了非常方便的API,使用

这些API可以开发面向服务(SOA)的程序。

支持多个重要的Web Service标准,包括SOAP、WSDL、WS-I Basic Profile、WSAddressing

、WS-Security等

? 高性能的SOAP栈

? 可选的绑定(binding)方式,如POJO、XMLBeans,JAXB1.1、JAXB2.0、Castor和JiBX等

? 支持JSR181 API

? 多种传输方式,如HTTP、JMS、XMPP、In-JVM等

? 灵活的接口

? 支持多个容器,如Spring、Pico、Plexus、Loom

? 支持JBI,参看servicemix项目(http://servicemix.org)

? 客户端和服务器代码生成

二.简单例子

A.发布web service

1.新建一个web 工程,加入xfire所依赖的lib,配置web.xml:

<?xml version="1.0" encoding="UTF-8"?>

<web-app version="2.4"

    xmlns="http://java.sun.com/xml/ns/j2ee"

    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

    xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee

    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

<servlet>

<servlet-name>XFireServlet</servlet-name>

<display-name>XFire Servlet</display-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>

</web-app>

在这个web.xml文件中定义了一个 XfireServlet,它负责提供Web Services,并提供每个Web Service的WSDL。通过网址http://<server_url[:port]>/<context>/services/XXXXService?WSDL得到这个Web Service的WSDL信息。

2.编写要发布的接口和实现,与普通的POJO没有任何区别。

package cn.cares;



public interface HelloService {

    public String hello(String name);

}

package cn.cares;



public class HelloServiceImpl implements HelloService {



    public String hello(String name) {

       // TODO Auto-generated method stub

       return "HI,"+name!=null? name:"Guest";

    }



}

3.在源文件src目录下新建  META-INF/xfire/services.xml,编译发布时会复制到WEB-INF/classes/META-INF/xfire下.

services.xml: (写法有很多,要多研究下)

<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://xfire.codehaus.org/config/1.0">

  <service>

    <name>HelloService</name>

<namespace>http://cn.cares/HelloService</namespace>

<serviceClass>cn.cares.HelloService</serviceClass>

<implementationClass>cn.cares.HelloServiceImpl</implementationClass>

  </service>

</beans>

4.发布到web server 上,访问: http://localhost:8080/web_project_name/services

就可看到所发布的web service, 后面的蓝色的链接,就会得到这个Web Service

的WSDL信息。

B 客户端访问

方法一:

1.如果web service发布成功了,就要看如何使用这web service

根据WSDL生成客户端代码,我们采用eclipse plugin 这样更简单,也可采用ant

具体xfire插件安装: Help ->Software Updates->Find and Install->Search for new features to install->Create New Remote Site,并输入"XFire" 名字和http://dist.codehaus.org/xfire/update/ eclipse 更新站点。



2.File->new ->Other->XFire->Code generation from WSDL document

输入WSDL URL或PATH,以及要生成的客户端代码目录。



3.测试:

import cares.cn.helloservice.HelloServiceClient;

import cares.cn.helloservice.HelloServicePortType;



public class Test {

    public static void main(String[] args) {

       HelloServiceClient client = new HelloServiceClient();

       HelloServicePortType helloService = client.getHelloServiceHttpPort();

//     调用服务

       String result = helloService.hello("Tome");

       System.out.println("结果:" + result);

    }



}

注意: 当运行时可能失败,是因为提示缺少jar包,因此,要将commons-codec-1.3.jar和commons-httpclient-3.0.jar只放到lib中并在工程中引用

如果输出:HI,Tome  说明客户端调用web service 成功。整个过程就完成了。



方法二:

直接动态访问web service,测试代码如下:

import java.net.MalformedURLException;

import java.net.URL;



import org.codehaus.xfire.client.Client;



public class Test2 {

    public static void main(String[] args) throws MalformedURLException,Exception {

       Client client = new Client(

              new URL(

                     "http://localhost:8080/ws/services/HelloService?wsdl"));

       Object[] results = client.invoke("hello", new Object[] { "Tome" });

       //invoke的第一个参数你要调用的方法,第二参数表示调用方法传递的参数

       System.out.println((String) results[0]);

    }

}