已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Java RPC通信机制之XML-RPC二、举例下面举一个实际运用XML-RPC进行RPC调用的例子,XML-RPC规范有多种针对不同语言的实现,这里我们使用的是Apache的XML-RPC3.0RC1。在开始之前,需到/commons/index.html下载如下程序包:commons-codec-1.3(通用编码/解码算法实现,可参考/Java/Article/29795/1954?pf=true或/commons/codec/userguide.html来获得该软件包的详细信息)commons-httpclient-3.0.1(HTTP协议的客户端编程工具包,详细介绍见/developerworks/cn/opensource/os-httpclient/)将上述通用工具包解压后,拷贝其中的jar文件到XML-RPC解压目录的dist目录中。并添加如下环境变量:XMLRPC_HOME XML-RPC的解压目录XMLRPC_LIB %XMLRPC_HOME%/distXMLRPCCLASSPATH %XMLRPC_LIB%/xmlrpc-common-3.0rc1.jar;%XMLRPC_LIB%/xmlrpc-server-3.0rc1.jar;%XMLRPC_LIB%/xmlrpc-client-3.0rc1.jar;%XMLRPC_LIB%/commons-httpclient-3.0.1.jar;%XMLRPC_LIB%/commons-codec-1.3.jar 整个应用很简单,通过XML-RPC调用Server端提供的HelloHandler.sayHello方法回显一个字符串信息。下面是HelloHandler接口及其实现类相关代码:/ HelloHandler.javapackage demo.xmlrpc; public interface HelloHandler public String sayHello(String str); / HelloHandlerImpl.javapackage demo.xmlrpc; public class HelloHandlerImpl implements HelloHandler public String sayHello(String str) return Hello, + str + !; 以下是对应的Server端源代码:/ Server1.javapackage demo.xmlrpc; import java.io.IOException;import java.io.OutputStream;import javax.servlet.ServletConfig;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse; import org.apache.xmlrpc.XmlRpcException;import org.apache.xmlrpc.server.PropertyHandlerMapping;import org.apache.xmlrpc.server.XmlRpcServerConfigImpl;import org.apache.xmlrpc.webserver.XmlRpcServletServer; public class Server1 extends HttpServlet private XmlRpcServletServer server; public void init(ServletConfig pConfig) throws ServletException super.init(pConfig); try / create a new XmlRpcServletServer object server = new XmlRpcServletServer(); / set up handler mapping of XmlRpcServletServer object PropertyHandlerMapping phm = new PropertyHandlerMapping(); phm.addHandler(HelloHandler, HelloHandlerImpl.class); server.setHandlerMapping(phm); / more config of XmlRpcServletServer object XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl)server.getConfig(); serverConfig.setEnabledForExtensions(true); serverConfig.setContentLengthOptional(false); catch (XmlRpcException e) try log(Failed to create XmlRpcServer: + e.getMessage(), e); catch (Throwable ignore) throw new ServletException(e); public void doPost(HttpServletRequest pRequest, HttpServletResponse pResponse) throws IOException, ServletException server.execute(pRequest, pResponse); 以下是对应的Client端源代码:/ Client1.javapackage demo.xmlrpc; import java.io.IOException;import .MalformedURLException;import java.util.Vector;import .URL; import org.apache.xmlrpc.XmlRpcException;import org.apache.xmlrpc.client.XmlRpcClient;import org.apache.xmlrpc.client.XmlRpcClientConfigImpl; public class Client1 public static void main(String args) try / config client XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl(); config.setServerURL(new URL(http:/localhost:8080/jsp/XmlRpcServer); / should be modified according to your configuration of jsp container / create a new XmlRpcClient object and bind above config object with it XmlRpcClient client = new XmlRpcClient(); client.setConfig(config); / create parameter list Vector params = new Vector(); params.addElement(Tom); / execute XML-RPC call String result = (String) client.execute(HelloHandler.sayHello, params); System.out.println(result); catch (MalformedURLException e) System.out.println(e.toString(); catch (XmlRpcException e) System.out.println(e.toString(); catch (IOException e) e.printStackTrace(); 程序源码中已包含了详细的注释,这里就不作过多解释了。但需注意XmlRpcDemo_Client中的ServerURL信息应根据自己的的jsp容器的配置作相应调整,并需设置相应的servlet-mapping信息,在我的jsp目录(Tomcat5.5的Context之一)下的WEB_INF/web.xml文件中存在如下的servlet-mapping信息: XmlRpcServer demo.xmlrpc.Server1 XmlRpcServer /XmlRpcServer并且,上述Server1.class及其他相关类文件已被拷贝到jspWEB-INFclassesdemoxmlrpc目录下。在启动Tomcat并执行java -classpath %CLASSPATH%;%XMLRPCCLASSPATH% demo.xmlrpc.Client1.java前,你应该将%XMLRPC_HOME%/dist、%XMLRPC_HOME%/lib下的几个jar文件(source就不用拷了)及前面下载的commons-codec-1.3.jar拷贝到%TOMCAT_HOME%/common/lib或jspWEB-INFlib下。Note:除了上面这种方式,你可以无需编写任何Server端代码,仅通过简单配置完成上述功能,具体可参考:/xmlrpc/server.html接下来,作为比较,我们来看看XML-RPC2.0中应该如何实现上述功能。以下是2.0版的Server程序:/ Server2.javapackage demo.xmlrpc; import java.io.IOException;import java.io.OutputStream; import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse; import org.apache.xmlrpc.XmlRpcServer; public class Server2 extends HttpServlet public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException XmlRpcServer xmlrpc = new XmlRpcServer(); xmlrpc.addHandler(HelloHandler, new HelloHandlerImpl(); byte result = xmlrpc.execute(request.getInputStream(); response.setContentType(text/xml); response.setContentLength(result.length); OutputStream out = response.getOutputStream(); out.write(result); out.flush(); 以下是2.0版的Client程序:/ Client2.javapackage demo.xmlrpc; import java.io.IOException;import .MalformedURLException;import java.util.Vector; import org.apache.xmlrpc.XmlRpcClient;import org.apache.xmlrpc.XmlRpcException; public class Client2 public static void main(String args) try XmlRpcClient xmlrpc = new XmlRpcClient(http:/localhost:8080/jsp/XmlRpcServer); Vector params = new Vector(); params.addElement(Tom); String result = (String) xmlrpc.execute(HelloHandler.sayHello, params); System.out.println(result); catch (MalformedURLException e) System.out.println(e.toString(); catch (XmlRpcException e) System.out.println(e.toString(); catch (IOException e) e.printStackTrace(); 总体上看,3.0比2.0在可配置性方面有了一些改进,其它方面则没有太大变化,但由于功能模块的分离,使得3.0较2.0显得更为复杂,已经习惯了2.0单一模块风格的开发者可能需要一些时间适应这种变化。三、其它特性除了上面的基本功能,XML-RPC3还支持动态代理/工厂和异步通信等特性。通过运用动态代理特性,我们可以在Server端及Client端共享接口信息,从而在编译期间进行必要的类型检查,在XML-RPC内部,所有的调用仍然是被动态转发给XmlRpcClient对象来完成的。但要使用XML-RPC3的动态代理功能,相应的服务器端的处理器类名称必须是Client端接口类的全名(含包名,该名称一般应该与Server端接口类全名一致),否则将会导致调用失败。以上面的HelloHandler接口为例,其对应的处理器类名称应该为:demo.xmlrpc.HelloHandler。Note: 动态代理(JDK1.3引入)是Proxy模式、依赖注入(Dependency Injection)及动态代码生成等技术相结合的一种应用,在各新型Web应用框架及容器中被广泛采用。而要使用XML-RPC的异步通信功能,只需实现org.apache.xmlrpc.client.AsyncCallback接口,该接口包括两个方法:public void handleResult(XmlRpcRequest pRequest, Object pResult);public void handleError(XmlRpcRequest pRequest, Throwable pError);此外,为了便于在普通应用中使用XML-RPC,XML-RPC还提供了一个WebServer类,以便在应用中内嵌一个HTTP服务器,为Client程序提供HTTP服务。下面的范例演示了上面提到的几种特性,以下是Server端代码:/ Server3.javapackage demo.xmlrpc; import org.apache.xmlrpc.server.PropertyHandlerMapping;import org.apache.xmlrpc.server.XmlRpcServer;import org.apache.xmlrpc.server.XmlRpcServerConfigImpl;import org.apache.xmlrpc.webserver.WebServer; public class Server3 private static final int port = 8080; public static void main(String args) throws Exception WebServer webServer = new WebServer(port); XmlRpcServer xmlRpcServer = webServer.getXmlRpcServer(); PropertyHandlerMapping phm = new PropertyHandlerMapping(); phm.addHandler(demo.xmlrpc.HelloHandler, HelloHandlerImpl.class); xmlRpcServer.setHandlerMapping(phm); XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl)xmlRpcServer.getConfig(); serverConfig.setEnabledForExtensions(true); serverConfig.setContentLengthOptional(false); webServer.start(); 下面是Client端代码:/ Client3.javapackage demo.xmlrpc; import .URL;import java.util.List;import java.util.Vector; import org.apache.xmlrpc.XmlRpcRequest;import org.apache.xmlrpc.XmlRpcException;import org.apache.xmlrpc.client.XmlRpcClient;import org.apache.xmlrpc.client.XmlRpcClientConfigImpl;import org.apache.xmlrpc.client.AsyncCallback;import org.apache.xmlrpc.client.util.ClientFactory; class EchoCallback implements AsyncCallback public void handleResult(XmlRpcRequest pRequest, Object pResult) System.out.println(Server returns: + (String)pResult); public void handleError(XmlRpcRequest pRequest, Throwable pError) System.out.println(Error occurs: + pError.getMessage(); public class Client3 public st
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 深度解析(2026)《GBT 3884.4-2012铜精矿化学分析方法 第4部分:氧化镁量的测定 火焰原子吸收光谱法》
- 2026年全国小学二年级下册期末真题卷含答案
- 深度解析(2026)《GBT 2951.31-2008电缆和光缆绝缘和护套材料通 用试验方法 第31部分:聚氯乙烯混合料专用试验方法 高温压力试验-抗开裂试验》
- 《JBT 10727-2007振幅递减椭圆振动筛》专题研究报告
- 2026年初中七年级上册各科易错知识点专项突破卷含答案
- 《JBT 10684-2006无润滑摆动空气压缩机》专题研究报告
- 《JBT 10469.1-2020冶金设备 气动盘式制动器 第1部分:常开型》专题研究报告
- 管理导购协议书模板
- 2026年测评自媒体工具:传声港全域营销生态重构品牌增长新范式
- 吉林高考:地理高频考点总结
- 八宝茶课件教学课件
- 考古勘探安全生产制度
- 炼钢厂防混钢制度规范
- 淘宝客培训课件
- 2025考研政治简答题专项卷含答案
- 人教版(2024)七年级上册数学期末培优试卷3(含答案)
- 烧伤后瘢痕教学课件
- 罗森加盟合同范本
- 幼儿园中班食品安全教育课件
- 高等学校实验室安全检查项目表(2026年)
- 危险化学品安全管理制度及事故应急预案
评论
0/150
提交评论