Xfire基础
XFire 是与 Axis 2 并列的新一代 Web Service 框架,通过提供简单的 API 支持 Web Service 各项标准协议,能够快速地开发 Web Service 应用。和其他 Web 服务引擎相比,XFire 的配置非常简单,可以非常容易地和 Spring 集成。
以下以一个实例讲解如何编写一个 Xfire 的服务端与客户端:
xfire版本:xfire-distribution-1.2.6.zip
目录结构:
关键代码:
User.javapackage com.alfred.xfire.bean;
public class User {
private String id;
private String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
IHelloService.javapackage com.alfred.xfire.service;
import com.alfred.xfire.bean.User;
public interface IHelloService {
public String sayHello(String name);
public User getUser(User user);
}
HelloService.javapackage com.alfred.xfire.service;
import com.alfred.xfire.bean.User;
public class HelloService implements IHelloService {
public String sayHello(String name) {
return "Hello, " + name;
}
public User getUser(User user) {
User userNew = new User();
userNew.setId("next" + user.getId());
userNew.setName("next" + user.getName());
return userNew;
}
}
ClientTest.javapackage com.alfred.xfire.client; import java.net.MalformedURLException;
import java.net.URL; import org.codehaus.xfire.XFire;
import org.codehaus.xfire.XFireFactory;
import org.codehaus.xfire.client.Client;
import org.codehaus.xfire.client.XFireProxyFactory;
import org.codehaus.xfire.service.Service;
import org.codehaus.xfire.service.binding.ObjectServiceFactory; import com.alfred.xfire.bean.User;
import com.alfred.xfire.service.IHelloService; public class ClientTest { public static void main(String[] args) {
// visitMethod01();
visitMethod02();
} private static void visitMethod01() {
try {
Client client = new Client(
new URL(
"http://127.0.0.1:8080/XfireDemo/services/HelloService?wsdl"));
Object[] results = client.invoke("sayHello",
new Object[] { "alfred" });
System.out.println(results[0].toString());
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
} private static void visitMethod02() {
// Create a metadata of the service 创建一个service的元数据
Service srvcModel = new ObjectServiceFactory()
.create(IHelloService.class);
// Create a proxy for the deployed service 为XFire获得一个代理工厂那个对象
XFire xfire = XFireFactory.newInstance().getXFire();
XFireProxyFactory factory = new XFireProxyFactory(xfire);
String url = "http://127.0.0.1:8080/XfireDemo/services/HelloService";
try {
IHelloService helloService = (IHelloService) factory.create(
srvcModel, url);
User user = new User();
user.setId("userid");
user.setName("alfred");
User newUser = helloService.getUser(user);
System.out.println("id:" + newUser.getId());
System.out.println("name:" + newUser.getName());
} catch (Exception e) {
e.printStackTrace();
}
} }
services.xml<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://xfire.codehaus.org/config/1.0">
<service>
<name>HelloService</name>
<namespace>com.alfred.xfire.service</namespace>
<serviceClass>com.alfred.xfire.service.IHelloService</serviceClass>
<implementationClass>com.alfred.xfire.service.HelloService</implementationClass>
</service>
</beans>
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>
<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>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
导入 jar 包:

将 xfire-all-1.2.6.jar 以及 lib 目录下的 jar 包全部导入即可。
services.xml 文件默认的存放目录是 WEB-INF/META-INF/xfire 下或 WEB-INF/classes/META-INF/xfire 下,如果是后者,那么实际项目中 META-INF 应放置于 src 目录下:

这样,部署到服务器中后 META-INF 文件夹就会存在于 WEB-INF/classes/ 目录下。如果要自己指定 services.xml 文件路径,可以将 services.xml 路径配置在 web.xml 文件中,如下:
<servlet>
<servlet-name>XFireServlet</servlet-name>
<servlet-class>
org.codehaus.xfire.transport.http.XFireConfigurableServlet
</servlet-class>
<!--
The servlet will by default look for the configuration on
the classpath in "META-INF/xfire/services.xml". You can
override it with this parameter. Seperate multiple configuration files with a comma.
-->
<!-- 默认会在classpath的META-INF/xfire/下查找services.xml文件,
可以覆盖这个参数,指定多个配置文件-->
<init-param>
<param-name>config</param-name>
<param-value>xfire-services.xml</param-value>
</init-param>
</servlet>
插入一段 init-param 配置,param-name 为 config,指定 services.xml 文件的路径以及文件名。
配置后目录结构如下:

客户端调用
xfire 的客户端有三种调用方式:
1、直接通过 url 调用, 不用客户端提供接口类
private static void visitMethod01() {
try {
Client client = new Client(
new URL(
"http://127.0.0.1:8080/XfireDemo/services/HelloService?wsdl"));
Object[] results = client.invoke("sayHello",
new Object[] { "alfred" });
System.out.println(results[0].toString());
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
2、通过服务端提供的接口类进行调用
private static void visitMethod02() {
// Create a metadata of the service 创建一个service的元数据
Service srvcModel = new ObjectServiceFactory()
.create(IHelloService.class);
// Create a proxy for the deployed service 为XFire获得一个代理工厂那个对象
XFire xfire = XFireFactory.newInstance().getXFire();
XFireProxyFactory factory = new XFireProxyFactory(xfire);
String url = "http://127.0.0.1:8080/XfireDemo/services/HelloService";
try {
IHelloService helloService = (IHelloService) factory.create(
srvcModel, url);
User user = new User();
user.setId("userid");
user.setName("alfred");
User newUser = helloService.getUser(user);
System.out.println("id:" + newUser.getId());
System.out.println("name:" + newUser.getName());
} catch (Exception e) {
e.printStackTrace();
}
}
3、通过服务端的 WSDL 反向生成客户端,很多 IDE 或者使用 Ant 都可以反向生成客户端,这里就不复诉了
三种客户端比较:
第一种方式是最为简便的,只需要URL就可以访问到,但是在效率上要低于另外两种方式。如果在可以得到服务端提供的接口类的情况下,最好的方法是使用第二种方式调用,效率最高。第三种方式其实和第二种有些类似(但估计没有第二种效率高,毕竟反向生成,可能会加入很多适用性的代码)。另外,就传递和返回数据来说,第一种方式只能传递基本数据类型或String等,无法传递接收自定义对象,后两种方式可以,当然,如果想要用第一种方式传递自定义对象可以先通过xstream等工具将其转换为XML字符串,然后传递解析,就可以了。
源码解析
org.codehaus.xfire.transport.http.XFireConfigurableServlet文件中,载入 services.xml 的相关代码如下:
private final static String CONFIG_FILE = "META-INF/xfire/services.xml"; private final static String PARAM_CONFIG="config"; /**
* Path to configuration file
*/
private String configPath; /**
* @return
*/
private String getConfigPath()
{
if (configPath == null || configPath.length() == 0)
{
return CONFIG_FILE;
}
return configPath;
} public XFire createXFire() throws ServletException
{
configPath = getInitParameter(PARAM_CONFIG);
XFire xfire;
try
{
xfire = loadConfig(getConfigPath());
}
catch (XFireException e)
{
throw new ServletException(e);
} if(xfire == null || xfire.getServiceRegistry() == null || xfire.getServiceRegistry().getServices() == null || xfire.getServiceRegistry().getServices().size() == 0)
{
xfire = super.createXFire();
} return xfire;
}
可以看到默认的 service.xml 加载路径为:
private final static String CONFIG_FILE = "META-INF/xfire/services.xml";
当创建 xfire 时会去加载 configPath:
configPath = getInitParameter(PARAM_CONFIG);
private final static String PARAM_CONFIG="config";
如果此时没有设置 config 参数那么就会取用默认 services.xml 路径配置:
private String getConfigPath()
{
if (configPath == null || configPath.length() == 0)
{
return CONFIG_FILE;
}
return configPath;
}
由此可见我们可以在 web.xml 里修改 config 参数进行路径配置。
Xfire基础的更多相关文章
- 从xfire谈WebService接口化编程
前段时间有博友在看我的博文<WebService入门案例>后,发邮件问我关于WebService 接口在java中的开发,以及在实际生产环境中的应用.想想自己入职也有一段时间了,似乎也该总 ...
- MyEclipse下XFire开发Webservice实例
XFire Java SOAP框架概述 (摘自:http://tech.it168.com/j/e/2006-10-28/200610281432707.shtml ) MyEclipse W ...
- xfire框架内部基本结构解析
1 概述 xfire是webservice的一个实现框架,是apache旗下CXF的前身,是一个比较被广泛使用的webservice框架,网上有很多关于如何使用xfire或cxf的hello worl ...
- MyEclipse下一个XFire发展Webservice示例
最近的研究JAVA发展Webservice.网络发现几个热门选择AXIS.XFire.CFX(XFire下一代),打开前几天对这篇文章比较三种选择,他们已经有了一些概念. 样本,以确定自己的实践 在開 ...
- WebService基础学习(二)—三要素
一.Java中WebService规范 JAVA 中共有三种WebService 规范,分别是JAX-WS.JAX-RS.JAXM&SAAJ(废弃). 1.JAX-WS规范 ...
- webService基础知识--认识WebService
之前在找工作的时候,有面试官问到WebService,当时没有接触过,正好现在做的项目中有用到WebService,所以就趁着业余时间来学习了. 一.简介 先来看看百度百科对WebService的解释 ...
- 使用xfire搭建webService服务
后边有个项目需要接入4A,要用到webService服务,暂时还不确定是不是会有我的事,但为了有备无患,还是抽时间学习了以下相关的知识. 本来我所了解到的发布webService服务有用cxf和xfi ...
- Web Service基础——规范及三要素
1. Java中的Web Service规范 Java 中共有三种WebService 规范,分别是JAX-WS(JAX-RPC).JAX-RS.JAXM&SAAJ(废弃). 1.1 JAX- ...
- Web service 框架比较CXF xfire aisx2 aisx
Web 服务框架.它还体现了从 Axis 1.x 系列获得的经验和最近两年在 Web 服务领域的发展.推出 Axis2 的主要原因之一是从速度和内存方面获得更好的性能——不过还添加了一些新特性和功能. ...
随机推荐
- Python字符串拼接的6种方法
如有其他字符串拼接方法 欢迎留言提出哦 (示例版本为Py2) 1. 加号 第一种,有编程经验的人,估计都知道很多语言里面是用加号连接两个字符串,Python里面也是如此直接用 “+” 来连接两个字符串 ...
- Docker For Mac没有docker0网桥
在使用Docker时,要注意平台之间实现的差异性,如Docker For Mac的实现和标准Docker规范有区别,Docker For Mac的Docker Daemon是运行于虚拟机(xhyve) ...
- python-面向对象-12_模块和包
模块和包 目标 模块 包 发布模块 01. 模块 1.1 模块的概念 模块是 Python 程序架构的一个核心概念 每一个以扩展名 py 结尾的 Python 源代码文件都是一个 模块 模块名 同样也 ...
- double类型相减有小数误差
如 :19.9-9.9=9.9999999999999,而不是10double相减会转换成二进制,因double有效位数为 16位这就会出现存储小数位数不够的情况,这种情况下就会出现误差 //两个Do ...
- 万恶之源 - Python装饰器及内置函数
装饰器 听名字应该知道这是一个装饰的东西,我们今天就来讲解一下装饰器,有的铁子们应该听说,有的没有听说过.没有关系我告诉你们这是一个很神奇的东西 这个有多神奇呢? 我们先来复习一下闭包 def fun ...
- SpringBoot 项目健康检查与监控(转)
前言 You build it,You run it, 当我们编写的项目上线后,为了能第一时间知晓该项目是否出现问题,常常对项目进行健康检查及一些指标进行监控.Spring Boot-Actuator ...
- [LeetCode] 329. Longest Increasing Path in a Matrix_Hard tag: Dynamic Programming, DFS, Memoization
Given an integer matrix, find the length of the longest increasing path. From each cell, you can eit ...
- 转: Java LinkedList基本用法
LinkedList类是双向列表,列表中的每个节点都包含了对前一个和后一个元素的引用.LinkedList的构造函数如下1. public LinkedList(): ——生成空的链表2. publ ...
- Java语言基础问题
1. 一个Java类文件中可以有几个公有类 在eclipse中测试代码时会出现上图所示的错误,此处只允许用final或abstract来修饰类,也就是一个类文件中只能有一个public修饰的类,此下对 ...
- web.config或App.config中AttachDBFilenamex相对路径问题
<add name="employeeManagerConnectionString" connectionString="Data Source=.\SQLExp ...