1.xml rpc是什么
1.1. xml rpc简介
xml rpc是使用http协议做为传输协议的rpc机制,使用xml文本的方式传输命令和数据。
一个rpc系统,必然包括2个部分:1.rpc client,用来向rpc server调用方法,并接收方法的返回数据;2.rpc server,用于响应rpc client的请求,执行方法,并回送方法执行结果。
1.2. xml rpc的可用版本
xml rpc client和xml rpc server都有很多版本的实现。一般而言,一个实现版本都会同时实现client/server。但由于都满足xml rpc规范,从理论上讲,任何一个版本的rpc client实现与任何一个版本的rpc server都能配套使用。
更进一步,由于xml rpc以xml文本的方式,使用http协议传输,所以与编程语言无关。例如:rpc client的已实现版本包括了:perl,php,python,c/c++,java,等等;rpc server的实现语言包括perl,java,等。
同一种编程语言所实现的版本也不止一个。例如java版的实现有:Marque的xmlrpc实现(http://xmlrpc.sourceforge.net/),apache的xmlrpc 实现(http://ws.apache.org/xmlrpc/)
1.3.xmlrpc的工作原理
完整的需要参考xmlrpc规范(http://www.xmlrpc.com/spec)
简单描述:
rpcclient的工作原理:rpcclient根据URL找到rpcserver -> 构造命令包,调用rpcserver上的某个服务的某个方法 -> 接收到rpcserver的返回,解析响应包,拿出调用的返回结果。
rpcserver的工作原理:启动一个webserver(在使用内置的webserver的情况下) -> 注册每个能提供的服务,每个服务对应一个Handler类 ->进入服务监听状态。
1.4. xmlrpc规范
区区6页,讲的非常清楚,建议细看。http://www.xmlrpc.com/spec
2.在java中使用xml rpc的几个例子
2.0.环境准备:下载如下包并设置到CLASSPATH中
apache xmlrpc软件包(http://ws.apache.org/xmlrpc/)
commons-httpclient-3.0-rc4.jar
commons-codec-1.3.jar
2.1.使用apache的java xmlrpc实现版本,实现简单的加/减服务。参考附录中test.XmlRPCClient类与test.JavaServer类
2.2.使用apache的java xmlrpc实现版本,测试java的数据类型与xmlrpc数据类型的相互对应关系。参考附录中test2.XmlRPCClient类与test2.JavaServer类。
在这里简单描述一下:
>xmlrpc中的Array类型,对应到java中的Vector类型
例如:在RPC Server中的某个服务方法的返回值的声明类型是String[],但在Client中接收到的将是Vector对象;
反之,如果Client传送过去的调用参数为String[],但在RPC Server中所接收到的将是Vector对象
当然,如果我们不使用String[],直接声明为Vector,也是可以的。
>xmlrpc中的struct类型,对应到java中的Hashtable类型
> 其它的类型,如:String,int,double,boolean,Date等,都比较好对应。需要注意的是:在rpc Client中,如果使用到int/double/boolean这些基本类型时,需要将他们封装成一个相应的Object,例如: Integer/Double/Boolean。
2.3.使用apache的java xmlrpc实现版本,实现自定义类型的数据的传输
这个sample中,假设所传输的 object都实现了XmlRPCSerializable接口。这个例子的目的是:模拟unionmon中的 command对象。当假设所传输的数据是一个Object[]时,可以用这种方式传输。结合unionmon中的代码生成机制,每个vo的序列化/反序列化方法可以在代码生成过程中完成。同样地,vox的序列化/反序列化方法需要手写。
参考代码:附录中的test3.XmlRPCSerializable , test3.AccountVO , test3.XmlRPCClient , test3.JavaServer
2.4.不启动内置的WebServer,让tomcat支持rpc server。
做法:1.实现一个Servlet,并配置到tomcat中;2.让rpc client直接找这个servlet,获得服务。
注意rpc client使用的是http post方法,所以该servlet中只需要实现doPost方法。
过程:在tomcat中的web.xml增加如下配置:
SampleServiceServlet
test4.ServletXmlRPCServer
SampleServiceServlet
/SampleServiceServlet
参考类:附件中的test4.SampleService,test4.ServletXmlRPCServer,test4.XmlRPCClient
3.todolist
3.1.能否通过introspect方式,使得自定义类型的vo的序列化/反序列化工作自动完成.castor可以完成对象的xml binding,似乎可参考
3.2.soap协议比xmlrpc复杂并强大。soap不熟悉。另,soap一定与web service在一起用?能否不用web service,但使用soap做rmi的协议。
4.附录
4.1.附录1 xmlrpc所支持的数据类型(略)
4.2.附录2 xmlrpc数据类型与java语言的数据类型的映射(略)
4.3.参考资料
http://xmlrpc.sourceforge.net/ –Marque的xmlrpc实现
http://ws.apache.org/xmlrpc/ apache上xmlrpc server的实现
http://xmlrpc-c.sourceforge.net/xmlrpc-howto/xmlrpc-howto.html xmlrpc howto
http://www.sentom.net/list.asp?id=80 xml-rpc之实例
http://www.xmlrpc.com/spec xmlrpc规范
分享到:
相关推荐
在Java环境中,XMLRPC库是一个常用的选择,可以方便地实现客户端和服务端的通信。 本教程主要围绕以下几个知识点展开: 1. **XMLRPC的基本概念**: - XMLRPC的核心思想是通过XML来封装参数和返回值,然后通过HTTP...
7. **应用与优势** - XML-RPC因其简单、跨平台的特性,常用于分布式系统中的简单API交互,尤其是在早期Web服务和轻量级系统集成中。 - 它的局限在于XML的解析和传输效率较低,对于大数据量和高并发场景可能不太...
这个例子包括三个关键文件:HelloClient.java、HelloServer.java和HelloHandler.java。 1. **HelloServer.java**: 这是服务器端的代码,主要负责启动XMLRPC服务并暴露可供调用的方法。在"Hello World"的例子中,...
6. **与其他语言的交互**:因为XMLRPC基于标准的XML,所以它可以轻松地与Java、Python、Ruby、.NET等多种语言编写的服务进行交互。这对于多语言开发环境或跨平台集成来说非常有用。 7. **性能和效率**:虽然XML的...
标签中的“java client”指的是Java客户端编程,而“xmlrpc”则特指使用XML-RPC协议进行通信。理解RPC的基本原理和XML-RPC的实现方式,对于开发分布式系统和跨网络通信的Java应用至关重要。通过这个实例,我们可以...
这个工程是基于JDK 1.5构建的,这意味着它是面向Java 5及更高版本的。如果你的环境中使用的JDK版本不同,可能需要对代码进行适当的调整才能运行。 Tomcat是常用的Java应用服务器,这里提到Tomcat的端口配置为10000...
- 在JSP中,可以通过Java的XML-RPC库,如 `xmlrpc-client` 和 `xmlrpc-server`,来实现XML-RPC服务器端的功能。 4. **Delphi与JSP的交互流程** - Delphi客户端使用 `TXMLRPCClient` 创建一个指向JSP服务器的连接...
下面是 Client 端调用 Server 端的代码:// Client.javaimport org.apache.xmlrpc.XmlRpcClient;import org.apache.xmlrpc.XmlRpcException;public class Client { public static void main(String[] args) { try { ...
总结一下,Delphixmlrpc是一个关于如何在Delphi应用中利用XML-RPC协议与Java服务器进行交互的例子。这个过程涉及到在Delphi中使用XML-RPC库创建和解析请求,以及在Java服务器上配置XML-RPC服务处理器。这种技术在...
3. "xmlrpc-negotiate-example.tar.gz":XML-RPC是一种远程过程调用(RPC)的协议,而Negotiate可能表示这个例子使用了安全的RPC调用,可能涉及到Kerberos或NTLM进行身份验证。 4. "Simplify enterprise Java ...
2.1. 简介 2.1.1. 关于资源(Resource) 2.1.2. 关于角色(Role) 2.1.3. 创建访问控制列表(ACL) 2.1.4. 注册角色(Role) 2.1.5. 定义访问控制 2.1.6. 查询 ACL 2.2. 精细的访问控制 2.2.1. 精细的访问控制 ...