一、什麼是XML-RPC
xml-rpc 是一套允許運行在不同操作系統、不同環境的程序實現基於internet過程調用的規範和一系列的實現。
這種遠程過程調用使用http作爲傳輸協議,xml作爲傳送信息的編碼格式。Xml-Rpc的定義儘可能的保持了簡單,但同時能夠傳送、處理、返回複雜的數據結構。
Xml-rpc是工作在internet上的遠程過程調用協議。一個xml-rpc消息就是一個請求體爲xml的http-post請求,被調用的方法在服務器端執行並將執行結果以xml格式編碼後返回。
- Request example
- Here's an example of an XML-RPC request:
- POST /RPC2 HTTP1.0
- User-Agent: Frontier5.1.2 (WinNT)
- Host: betty.userland.com
- Content-Type: textxml
- Content-length: 181
- <?xml version="1.0"?>
- <methodCall>
- <methodName>examples.getStateName</methodName>
- <params>
- <param>
- <value><i4>41</i4></value>
- </param>
- </params>
- </methodCall>
- Response example
- Here's an example of a response to an XML-RPC request:
- HTTP1.1 200 OK
- Connection: close
- Content-Length: 158
- Content-Type: textxml
- Date: Fri, 17 Jul 1998 19:55:08 GMT
- Server: UserLand Frontier5.1.2-WinNT
- <?xml version="1.0"?>
- <methodResponse>
- <params>
- <param>
- <value><string>South Dakota</string></value>
- </param>
- </params>
- </methodResponse>
二、xml-rpc入門程序
以下的入門程序包括一個管理器(HelloHandler)、一個服務器(HelloServer)、一個客戶程序(HelloClient)。
首先要做的是創建用於遠程過程調用的類和方法,人們常常稱之爲管理器。Xml-rpc管理器是一個方法和方法集,它接受xml-rpc請求,並對請求的內容進行解碼,再向一個類和方法發出請求。
//管理器類
//服務器類
- package xmlRpc;
- /**
- *
- * <b><code>HelloServer</code></b> is a simple XML-RPC server
- * that will take the <code>HelloHandler</code> class available
- * for XML-PRC calls.
- *
- */
- import org.apache.xmlrpc.WebServer;
- import org.apache.xmlrpc.XmlRpc;
- import java.io.IOException;
- public class HelloServer {
- public static void main(String[] args){
- if(args.length<1){
- System.out.println("Usage: java HelloServer [port]");
- System.exit(-1);
- }
- try{
- XmlRpc.setDriver("org.apache.xerces.parsers.SAXParser");
- //start the server
- System.out.println("Starting XML-RPC Server......");
- WebServer server = new WebServer(Integer.parseInt(args[0]));
- //register our handler class
- server.addHandler("hello",new HelloHandler());
- System.out.println("Now accepting requests......");
- }catch(ClassNotFoundException e){
- System.out.println("Could not locate SAX Driver");
- }catch(IOException e){
- System.out.println("Could not start server: "+e.getMessage());
- }
- }
- }
- package xmlRpc;
- /**
- *
- * <b><code>HelloClient</code></b> is a simple XML-RPC client
- * that makes an XML-RPC request to <code>HelloServer</code>
- */
- import java.io.IOException;
- import java.util.Vector;
- import org.apache.xmlrpc.XmlRpc;
- import org.apache.xmlrpc.XmlRpcClient;
- import java.net.MalformedURLException;
- import org.apache.xmlrpc.XmlRpcException;
- public class HelloClient {
- public static void main(String[] args){
- if(args.length<1){
- System.out.println("Usage: java HelloClient [your name]");
- System.exit(-1);
- }
- try{
- //Use the Apache Xereces SAX Driver
- XmlRpc.setDriver("org.apache.xerces.parsers.SAXParser");
- //Specify the server
- XmlRpcClient client = new XmlRpcClient("http://localhost:8585");
- //create request
- Vector params = new Vector();
- params.addElement(args[0]);
- //make a request and print the result
- String result = (String)client.execute("hello.sayHello",params);
- System.out.println("Response from server: "+ result);
- }catch(ClassNotFoundException e){
- System.out.println("Could not locate SAX Driver");
- }catch(MalformedURLException e){
- System.out.println("Incorrect URL fro xml-rpc server foramt:"+e.getMessage());
- }catch(XmlRpcException e){
- System.out.println("XmlRpcException :"+e.getMessage());
- }catch(IOException e){
- System.out.println("IOException:"+e.getMessage());
- }
- }
- }
三、RPC和RMI的簡單比較
在RMI和RPC之間最主要的區別在於方法是如何別調用的。在RMI中,遠程接口使每個遠程方法都具有方法簽名。如果一個方法在服務器上執行,但是沒有相匹配的簽名被添加到這個遠程接口上,那麼這個新方法就不能被RMI客戶方所調用。在RPC中,當一個請求到達RPC服務器時,這個請求就包含了一個參數集和一個文本值,通常形成“classname.methodname”的形式。這就向RPC服務器表明,被請求的方法在爲“classname”的類中,名叫“methodname”。然後RPC服務器就去搜索與之相匹配的類和方法,並把它作爲那種方法參數類型的輸入。這裏的參數類型是與RPC請求中的類型是匹配的。一旦匹配成功,這個方法就被調用了,其結果被編碼後返回客戶方。
trier 整理:
參考資料:
- http://www.xmlrpc.com/
《java&xml》O'Reilly