xFire客户端

合集下载

xfire使用

xfire使用

wsdlDocumentURL 代表wsdl所对应的URL1、通过URLConnection创建连接,然后invoke相应接口优点:调用简单缺点:传递封装对象比较麻烦[java]view plaincopyprint?1.// wsdlDocumentURL必须是全地址(包含?wsdl)2.URL url = new URL(wsdlDocumentURL);3.URLConnection connection = url.openConnection();4.Client client = new Client(connection.getInputStream(), null);5.// invoke接口方法6.// 接口返回Object数组7.Object[] result = client.invoke("methodName", new Object[]{});[java]view plaincopyprint?.codehaus.xfire.service.Service serviceModel = new ObjectServiceFactory().create(接口.class);2.XFireProxyFactory factory = new XFireProxyFactory(XFireFactory.newInstance().getXFire());3.IEmailBindHandlerService handler = (IEmailBindHandlerService) factory.create(serviceModel, wsdlURL);2、XFireProxyFactory创建客户端实例客户端需要明确知道接口详细信息[java]view plaincopyprint?.codehaus.xfire.service.Service serviceModel = new ObjectServiceFactory().create(IEmailBindHandlerService.class);2.XFireProxyFactory factory = new XFireProxyFactory(XFireFactory.newInstance().getXFire());3.接口 handler = (IEmailBindHandlerService) factory.create(serviceModel, wsdl地址);3、通过eclipse自动生成webservice client4、通过org.codehaus.xfire.spring.remoting.XFireClientFactoryBean构建客户端实例[java]view plaincopyprint?1.<bean id="baseService" class="org.codehaus.xfire.spring.remoting.XFireClientFactoryBean" abstract="true">2. <property name="serviceFactory" ref="xfire.serviceFactory" />3. <!-- <property name="lookupServiceOnStartup" value="false" /> -->4. <property name="properties">5. <props>6. <!-- 等待HttpConnectionManager从连接池中返回空闲连接的超时时间 -->7. <prop key="http.connection.manager.timeout">1000</prop>8. <!-- 等待建立连接的超时时间 -->9. <prop key="http.connection.timeout">3000</prop>10. <!-- 等待服务器返回数据超时时间 -->11. <prop key="http.timeout">10000</prop>12. <!-- 连接到单个服务器的连接数上限 -->13. <prop key="max.connections.per.host">10</prop>14. <!-- 连接到所有服务器的连接个数上限 -->15. <prop key="max.total.connections">80</prop>16. </props>17. </property>18. </bean>19.20. <bean id="接口实例" parent="baseService">21. <property name="serviceClass" value="接口地址" />22. <property name="wsdlDocumentUrl" value="${xfireServerURL}/webservice名称?wsdl" />23. </bean>使用该配置方法的话,可以通过注入实现调用,同时可以减少手动创建URLConnection之后忘记关闭连接的尴尬只是如果使用该方法的时候,需要在web.xml中添加如下配置[java]view plaincopyprint?1.<context-param>2. <param-name>contextConfigLocation</param-name>3. <param-value>classpath:org/codehaus/xfire/spring/xfire.xml</param-value>4.</context-param>。

webservice四种发布方式及客户端调用

webservice四种发布方式及客户端调用

WebService 四种发布方式总结Author:yczhang1.CXF方式CXF与spring搭建webservice是目前最流行的方式,但是传闻cxf与jdk1.5有些不兼容,我没有遇到过,我遇到的问题是cxf与was6.1.1不兼容,表现在cxf必须的jar包“wsdl4j-1.6.2.jar”报错,报的错为:ng.IncompatibleClassChangeError,明显的jar包不兼容问题,很是头痛,后来查找资料找到解决办法是,将上述jar包新建一个was共享库,可以解决,但是客户周经理不想用此种方式,因为需要修改was,于是改用了axis2方式,下文会介绍。

该问题在此处做个记录,以后使用cxf与was的时候需要注意!!!使用cxf+spring搭建WebService:第一步,添加jar包。

此处需要注意,不同环境(tomcat、was)jar也不一定相同,例如我本地cxf+spring只需要如下jar包:而泰康的was环境则需要如下jar包:明显的多了很多,原因应该是服务器jar包池的不同。

根据错误提示缺什么补什么就可以了,注意jar包勿重复。

第二步,配置web.xml文件,如下(重要的地方已标记):<context-param><param-name>contextConfigLocation</param-name><param-value>classpath:/applicationContext.xml</param-value> </context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener </listener-class></listener><!-- Character Encoding filter --><filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFil ter</filter-class><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><servlet><servlet-name>CXFServlet</servlet-name><servlet-class>org.apache.cxf.transport.servlet.CXFServlet</servlet-c lass><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>CXFServlet</servlet-name><url-pattern>/webservice/*</url-pattern></servlet-mapping>上述标记的地方,第一处是spring配置文件路径;第二出是wsdl地址内容;第三步,编写接口类与实现类,注意注解接口类@WebServicepublic interface SendService {public boolean sendOA(@WebParam(name="param")String param);public boolean sendOrg(OrgEntity org);}实现类@WebService(endpointInterface="com.service.SendService",serviceName=" sendService")public class SendServiceImpl implements SendService{public boolean sendOA(String param) {System.out.println("-------sendOA---------param:"+param);if(param.equals("zhoujian")){return true;}return false;}public boolean sendOrg(OrgEntity org) {System.out.println("-------sendOrg--begin-------");return true;}}第四步,Spring配置文件“jaxws:client”该标签可以不必写,访问时可以手动拼接该url 第五步,发布,直接部署到服务器,访问:2.Xfire方式据说xfire方式已经很老了,但个人感觉,xfire方式很简单且容易配置,不知为啥过时了,也没感觉cxf、axis2哪里先进,我当时卡在cxf与was搞不定时想尝试xfire方式被周经理给拒绝了。

XFire开发webservice服务和客户端全攻略

XFire开发webservice服务和客户端全攻略

使用XFire开发webservice服务和客户端全攻略收藏XFire 是与Axis 2并列的新一代Web Service框架,通过提供简单的API支持Web Service 各项标准协议,帮助你方便快速地开发Web Service应用。

相对于Axis来说,目前XFire相对受欢迎,加上其提供了和Spring集成的支持,在目前的Web Service开源社区拥有众多的追随者。

并且因为XFire为Spring提供的支持,使得我们可以很容易在Spring中使用XFire构建Web Service应用。

XFire 与Axis2相比具有如下特征:l 支持一系列Web Service的新标准--JSR181、WSDL2.0 、JAXB2、WS-Security 等;l 使用Stax解释XML,性能有了质的提高。

XFire采用Woodstox 作Stax实现;l 容易上手,可以方便快速地从pojo发布服务;l 支持Spring、Pico、Plexus、Loom等容器;l 灵活的Binding机制,包括默认的Aegis,xmlbeans,jaxb2,castor;l 高性能的SOAP 栈设计;l 支持Spring、Pico、Plexus、Loom等容器。

XFire 与Axis1性能的比较如下:l XFire 比Axis1.3快2-6倍;l XFire 的响应时间是Axis1.3的1/2到1/5。

XFire 在WebService框架中开始较晚,它从现有的框架中借鉴了许多优秀的理念,力争将Web Service的应用开发难度降到最低。

此外,还提供了各种绑定技术、支持多种传输协议,对WebService体系中许多新的规范提供了支持。

下面让我们来看一个XFire于Spring集成的helloWorld的简单例子。

一.实现的功能和特点本例具有如下功能和特点:1)基于J2EE平台的Web Service服务;2)开发方便,配置简单;3)与spring无缝集成。

如何在MyEclipse和Eclipse下安装XFire插件CXF插件 WebService

如何在MyEclipse和Eclipse下安装XFire插件CXF插件 WebService

如何在MyEclipse和Eclipse下安装XFire插件CXF插件 WebService首先,现在都用CFX了(CFX部分源于XFire)吧,所以建议大家使用CXF,本文后面讲XFire安装……CXF的安装参见:Apache CXF: An Open-Source Services Framework /源文件的下载在/download.html博客更新时最新为2.42 一共两个文件,要下载的是其中的二进制下载包,也就是Binary distribution,下载File下的zip(for win)或者tar.gz(for linux)我用的是winXP下载完成后按照如下配置:将你的Binary distribution加压至任意文件夹(将被设为%CXF_HOME%)我的电脑->属性->高级->环境变量创建一个CXF_HOME变量,值为CXF框架所在根目录,修改一下CLASSPATH=%CXF_HOME%/lib;PATH=%CXF_HOME%/bin; 以方便在DOS窗口下直接运行java2ws,wsdl2java等可执行文件。

在%JAVA_HOME%/jre/lib目录下创建一下endorsed文件夹,将jaxb-api.jar,jaxws.jar拷贝进去。

(建议在%CXF_HOME%的文件夹中搜索endorsed,就包括这两个文件,当然,你也可以直接将这个路径包含在%CXF_HOME%\lib\endorsed包含在CLASSPATH中尝试一下,我没有试过)配置好了后,你在DOS窗口下输入java2ws,看看配置是否有效,有效会提示Missing argument: classname。

这样就OK了。

MyEclipse安装XFire要进行基于XFire的开发,需要在MyEclipse或者Eclipse里安装XFire,但是网上基本没有安装插件的说明,在这里做一个介绍:在Eclipse里添加XFire,请遵照XFire官网说明/Eclipse+Plugin进行安装在MyEclipse (9.0)骤如下:进入help->MyEclipse Configer Center ,点选Software选项卡,左侧有个Browse Software,点击导航右侧的 Add Site,弹出对话框,填入名称“XFire”(任填)和站点"/xfire/update/",点击确定,稍等片刻,你会发现在Browse Software下多了XFire的两个选项(只是找到,还没安装),OK,分别双击这两个选项,这连个添加会排程到等待更新的列表中,也就是页面右下角的Software Updates Aviables里面(其实有一个确实已经在MyEclipse里面安装了,所以应该只有一个更新),在单选框中打对勾,然后更新,会弹出更新向导,然后默认的Next Next就可以了……新建一个工程,在工程添加向导里你可能看不到XFire的选项,不急,在工程添加完成后,在工程上右键,在菜单上会出现“为该工程配置XFire”特性,在这里设置就好了……针对之前没说清楚,在这里补充这一点……完……安装完毕,新建工程,右键->添加XFire支持虽然不能从新建工程向导中配置,也没问题,恩恩完……。

cxf框架的使用流程

cxf框架的使用流程

CXF框架的使用流程1. 什么是CXF框架?Apache CXF(前身是Xfire)是一个开源的Web服务框架,用于构建和开发服务导向架构(SOA)应用程序。

CXF提供了一种简单而强大的方式来创建、部署和管理Web服务,支持SOAP、REST、XML和JSON等多种协议。

它基于Java标准,可以与Java EE和Spring框架无缝集成,是一个功能丰富且灵活的框架。

2. CXF框架使用流程使用CXF框架开发Web服务通常有以下几个步骤:步骤一:创建Web服务的接口首先,需要定义Web服务的接口。

在接口中定义服务的方法,参数和返回值类型。

接口可以按照业务需求进行设计,并使用注解来标记服务方法。

步骤二:实现服务接口接下来,需要实现定义的接口。

在实现类中编写具体的服务逻辑代码。

可以根据业务需求调用其他服务或持久化数据。

步骤三:发布Web服务使用CXF框架提供的工具类将服务发布为Web服务。

可以通过Spring配置文件或Java代码的方式来发布服务。

步骤四:客户端调用服务编写客户端代码来调用已发布的Web服务。

可以使用CXF框架提供的工具类生成客户端代码,也可以手动编写客户端调用代码。

步骤五:部署和运行将服务端和客户端的代码部署到相应的容器或服务器上。

可以使用Maven等构建工具打包项目,并将生成的war或jar文件部署到Tomcat或其他容器中运行。

3. CXF框架使用示例下面是一个使用CXF框架开发Web服务的简单示例:步骤一:定义服务接口package com.example.service; import javax.jws.WebMethod;import javax.jws.WebService;@WebServicepublic interface HelloWorldService { @WebMethodString sayHello(String name);}步骤二:实现服务接口```java package com.example.service;import javax.jws.WebService;@WebService(endpointInterface =。

XFIRe概述

XFIRe概述

XFire 概述XFire 是 codeHaus 组织提供的一个开源框架,它构建了 POJO 和 SOA 之间的桥梁,主要特性就是支持将 POJO 通过非常简单的方式发布成 Web 服务,这种处理方式不仅充分发挥了 POJO 的作用,简化了 Java 应用转化为 Web 服务的步骤和过程,也直接降低了 SOA 的实现难度,为企业转向 SOA 架构提供了一种简单可行的方式。

XFire 目前最新的版本是 1.2.2,目前支持的特性主要包括:∙支持将 Web 服务绑定到 POJO、XMLBeans、JAXB1.1、JAXB2.0 和 Castor;∙支持基于 HTTP、JMS、XMPP 等多种协议访问 Web 服务;∙支持多种 Web 服务业界重要标准如 SOAP、WSDL、Web 服务寻址(WS-Addressing)、Web 服务安全(WS-Security)等;∙支持 JSR181,可以通过 JDK5 配置 Web 服务;∙高性能的 SOAP 实现;∙服务器端、客户端代码辅助生成;∙对 Spring、Pico、Plexus 等项目的支持等。

XFire 安装包XFire 框架目前的最新版本是 1.2.6,可以访问 下载XFire 框架的安装包,下载时请选择“全部二进制发布包(Binary Distribution in zip package)”,而不仅仅是“XFire jar 文件(Jar of all XFire modules)”。

下载完成后,我们可以将下载的 .zip 文件解压缩到任意的文件夹中(后面的章节中使用 % XFIRE_HOME % 表示 XFire 框架的安装目录),解压缩后形成的文件目录结构如下:∙api(目录)api 目录中是 XFire 框架中所有类(class)对应的 API 文档,为开发者使用 XFire 完成应用开发提供帮助。

∙examples(目录)examples 目录中包含了所有随 XFire 二进制包发布的实例,包括这些实例的源代码和相关 Web 应用配置内容。

Xfire指南

Xfire指南

Xfire指南1. 概述XFire是全球众多牛人在与axis系列对比后一致投票的选择。

我比较欣赏的特性有:1.与Spring整合,无须生成一堆文件,无须打包独立war,直接将应用中的Pojo导出为Web服务。

2.Aegis--超简约的默认Java XML 绑定机制,且可以Plugin其他绑定机制。

3.JSR181--annotatiton驱动的POJO WebService配置。

4.基于Stax的高性能框架。

5.脱离Web服务器的单元测试能力。

网上的文档与例子总是不新,请大家抛开所有的文档,所有的Axis 习惯,单看这份代表XFire1.2.2最简约做法的指南。

2. 生火指南2.1 修改web.xml,在Web应用中增加XFire的入口注意XFire有了自己的Servlet,不再依赖Spring MVC的DispatchServlet,也就远离了大家不熟悉的Spring MVC URL Mapping,与Spring达致完美的整合。

这里指定了路径为/service/* ,即WebService的URL会被默认生成为/yyy/service/BookServiceservice/ServiceName ,其中ServiceName默认为下文中的接口名。

xml 代码1.<servlet>2. <servlet-name>xfireservlet-name>3. <servlet-class>org.codehaus.xfire.spring.XFireSpringServletservlet-class>4. servlet>5. <servlet-mapping>6. <servlet-name>xfireservlet-name>7. <url-pattern>/service/*url-pattern>8. servlet-mapping>如果应用使用了Hibernate,使用了OpenSessionInView Filter,注意配置OSIV Filter Filter覆盖xfire servlet的路径,即本例中的/service/*.2.2 编写窄接口,抽取POJO中要导出的服务从已有的BookManager.java中,抽取出一个窄接口,仅暴露需要导出为Web Service的方法。

信步漫谈之Xfire—基础介绍

信步漫谈之Xfire—基础介绍

信步漫谈之Xfire—基础介绍XFire 是与 Axis 2 并列的新⼀代 Web Service 框架,通过提供简单的 API ⽀持 Web Service 各项标准协议,能够快速地开发 Web Service 应⽤。

和其他 Web 服务引擎相⽐,XFire 的配置⾮常简单,可以⾮常容易地和 Spring 集成。

以下以⼀个实例讲解如何编写⼀个 Xfire 的服务端与客户端:xfire版本:xfire-distribution-1.2.6.zip⽬录结构:关键代码:User.javaIHelloService.javaHelloService.javaClientTest.javaservices.xmlweb.xml导⼊ 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 onthe classpath in "META-INF/xfire/services.xml". You canoverride 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 ⽂件的路径以及⽂件名。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

xFire客户端生成及使用1.xFire客户端生成右键项目名称,new —other ,选择Code generation from WSDL document填写WSDL地址或者文件路径,(由客户端提供),已经生成代码存放的路径生成的文件如下:2.配置weblogic启动项1.由于xFire需要的jar,会与weblogic自带的jar文件产生冲突,所以weblogic启动时需要先加载一些jar :2.修改weblogic的启动配置。

对startWebLogic.cmd进行编辑,找到set CLASSPATH = 设置的地方,加上需要载入的jar,如:set CLASSPATH= %MEDREC_WEBLOGIC_CLASSPATH%修改成:(假设以上jar包存放在E:\lib\下面)set CLASSPATH=E:\lib\xfire-aegis-1.2.6.jar;E:\lib\xfire-jaxb2-1.2.6.jar;E:\lib\xfire-jsr181-api-1.0-M1.jar;E:\lib\qname.jar;E:\lib\wsdl4j-1.5.2.jar;E:\lib\jdom-1.0.jar;E:\lib\xfire-all-1.2.6.jar;E:\lib\jaxb-api-2.0.jar;E:\lib\commons-httpclient-3.0.jar;E:\lib\commons-codec-1.3.jar;E:\lib\commons-beanutils-1.7.0.jar;E:\lib\commons-beanutils-1.7.0.jar;E:\lib\commons-logging-1.0.4.jar;E:\lib\log4j-1.2.13.jar;%CLASSPATH%;%MEDREC_WEBLOGIC_CLASSPATH%3.代码编写1.服务调用根据xFire生成的客户端ScheduleWebServiceClient client = new ScheduleWebServiceClient(); ScheduleWebServicePortType service = client.getScheduleWebServiceHttpPort();这样,直接可以由service调用webService的接口。

2.数据封装:xFire 生成出来的调用webService 接口所需要的实体类都在vo 文件夹下面,在vo 类里面,与普通的java 实体一样,都包含属性 和 该属性的set,get 方法,但是除基本数据类型外,其他的类型都被封装成JAXBElement ,如String 类型,被封装成:JAXBElement<String>。

如:ScheduleDataForCheckVo.java生成一个xml 元素实例需要四个参数:public JAXBElement (QName name, //xml 元素标记名称的 Java 绑定Class <T > declaredType, // xml 元素声明类型的 Java 绑定Class scope, // xml 元素声明作用域的 Java 绑定T value) //表示 xml 元素值的 Java 实例1.JAXBElement<String>,JAXBElement<Long>类型:注意 new QName 时候的两个参数,对应着 vo 文件里面该属性注释中的name 和namespace.public class ScheduleDataForCheckVo {@XmlElementRef (name = "cancelContent", namespace = "", type = JAXBElement.class ) protected JAXBElement<String> cancelContent;public JAXBElement<String> getCancelContent() { return cancelContent;} public void setCancelContent(JAXBElement<String> value) {this .cancelContent = ((JAXBElement<String> ) value);} }于是,我们在给VO对象set值的时候,就应该这样写:scheduleDataVo.setCancelContent(New JAXBElement<String>(new QName("","cancelContent"),String.class,null,"要传递的值"));2.DATE类型,在VO类中会转变成XMLGregorianCalendar 类型,这时候我们需要将日期转化成 Calendar 类型,再转成 XMLGregorianCalendar 类型下面是我写的一个时间转换的公共方法:import mons.beanutils.*;import java.util.Calendar;import java.util.Date;import javax.xml.datatype.XMLGregorianCalendar;import .apache.xerces.internal.jaxp.datatype.XMLGregorianCalendarImpl;/***XMLGregorianCalendar和Calendar之间的转换器,适用于Apache Commons BeanUtils.copyProperties方法。

*//当需要转换为XMLGregorianCalendar类型时使用*ConvertUtils.register(* new XMLGregorianCalendarConverter(),* XMLGregorianCalendar.class);*//当需要转换为Calendar类型时使用*ConvertUtils.register(new XMLGregorianCalendarConverter(),Calendar.class);*BeanUtils.copyProperties(destObj,srcObj);*注意:java.util.Calendar的时区(ZONE_OFFSET)是以毫秒为单位的值。

</p>* //也可以直接传递 DATE 类型的数据进来* converter.convert(XMLGregorianCalendar.class,new Date())**/public class XMLGregorianCalendarConverter implements Converter {public Object convert(Class arg0, Object arg1) {if(arg1 instanceof XMLGregorianCalendar){return this.convert(arg0, (XMLGregorianCalendar)arg1);}else{return this.convert(arg0, (Calendar)arg1);}}public Calendar convert(Class calendarType, XMLGregorianCalendar xmlCalendar){ return xmlCalendar.toGregorianCalendar();}public XMLGregorianCalendar convert(Class xmlCalendarType, Calendar calendar){ XMLGregorianCalendar cal = new XMLGregorianCalendarImpl();cal.setYear(calendar.get(Calendar.YEAR));cal.setMonth(calendar.get(Calendar.MONTH) +1);cal.setDay(calendar.get(Calendar.DAY_OF_MONTH));cal.setHour(calendar.get(Calendar.HOUR_OF_DAY));cal.setMinute(calendar.get(Calendar.MINUTE));cal.setSecond(calendar.get(Calendar.SECOND));cal.setMillisecond(calendar.get(LISECOND));cal.setTimezone(calendar.get(Calendar.ZONE_OFFSET) / 60000 );return cal;}public XMLGregorianCalendar convert(Class xmlCalendarType, Date date){ if(date == null){date = new Date();date.setYear(0);System.out.println(" convert new Date() " + date);}Calendar calendar=Calendar.getInstance();calendar.setTime(date);return convert( XMLGregorianCalendar.class , calendar);}}。

相关文档
最新文档