Web Services:Apache XML-RPC

来源:互联网 发布:java zero copy 编辑:程序博客网 时间:2024/04/29 09:07
XML-RPC(http://ws.apache.org/xmlrpc/ )的全称是XML Remote Procedure Call,即XML程方法用。是JAVA实现的XML-RPC。     这种远程过程调用使用http作为传输协议,XML作为传送信息的编码格式。Xml-Rpc的定义尽可能的保持了简单,但同时能够传送、处理、返回复杂的数据结构。   XML-RPC是工作在Internet上的远程过程调用协议。一个XML-RPC消息就是一个请求体为xml的http-post请求,被调用的方法在服务器端执行并将执行结果以xml格式编码后返回。 ■All primitive Java types are supported, including long, byte, short, and double.■Calendar objects are supported. In particular, timezone settings, and milliseconds may be sent.■DOM nodes, or JAXB objects, can be transmitted. So are objects implementing the java.io.Serializable interface.■Both server and client can operate in a streaming mode, which preserves resources much better than the default mode, which is based on large internal byte arrays.    概念图如下:  和RMI类似,需要服务器类和客户端类。还需要配置web.xml. 服务器类代码片段:package org.apache.xmlrpc.demo.webserver;   import java.net.InetAddress;  import org.apache.xmlrpc.common.TypeConverterFactoryImpl;  import org.apache.xmlrpc.demo.webserver.proxy.impls.AdderImpl;  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 Server {      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();          /* Load handler definitions from a property file.           * The property file might look like:           *   Calculator=org.apache.xmlrpc.demo.Calculator           *   org.apache.xmlrpc.demo.proxy.Adder=org.apache.xmlrpc.demo.proxy.AdderImpl           */           phm.load(Thread.currentThread().getContextClassLoader(),"MyHandlers.properties");          /* You may also provide the handler classes directly,           * like this:           * phm.addHandler("Calculator",           *     org.apache.xmlrpc.demo.Calculator.class);           * phm.addHandler(org.apache.xmlrpc.demo.proxy.Adder.class.getName(),           *     org.apache.xmlrpc.demo.proxy.AdderImpl.class);           */          xmlRpcServer.setHandlerMapping(phm);           XmlRpcServerConfigImpl serverConfig =               (XmlRpcServerConfigImpl) xmlRpcServer.getConfig();          serverConfig.setEnabledForExtensions(true);          serverConfig.setContentLengthOptional(false);          webServer.start();      }  } web.xml配置片段:<servlet>        <servlet-name>XmlRpcServlet</servlet-name>        <servlet-class>org.apache.xmlrpc.webserver.XmlRpcServlet</servlet-class>        <init-param>          <param-name>enabledForExtensions</param-name>          <param-value>true</param-value>          <description>            Sets, whether the servlet supports vendor extensions for XML-RPC.          </description>        </init-param>    </servlet>    <servlet-mapping>        <servlet-name>XmlRpcServlet</servlet-name>        <url-pattern>/xmlrpc</url-pattern>    </servlet-mapping> 客户端代码片段:package web.service.xml.rpc; import java.net.MalformedURLException;import java.net.URL;import org.apache.xmlrpc.XmlRpcException;import org.apache.xmlrpc.client.XmlRpcClient;import org.apache.xmlrpc.client.XmlRpcClientConfigImpl;import org.apache.xmlrpc.client.XmlRpcCommonsTransportFactory;import org.apache.xmlrpc.client.util.ClientFactory; public class Client {     public static void main(String[] args) throws Exception {        // create configuration        XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl();        config.setServerURL(new URL("http://127.0.0.1:8080/WEBXMLRPC"));        config.setEnabledForExtensions(true);          config.setConnectionTimeout(60 * 1000);        config.setReplyTimeout(60 * 1000);        XmlRpcClient client = new XmlRpcClient();         // use Commons HttpClient as transport        client.setTransportFactory(            new XmlRpcCommonsTransportFactory(client));         // set configuration        client.setConfig(config);         // make the a regular call        Object[] params = new Object[]            { new Integer(2), new Integer(3) };        Integer result = (Integer) client.execute("calculator_test.add", params);        System.out.println("2 + 3 = " + result);    }} 这里的calculator_test.add关键字是在MyHandlers.properties中配置的。add是方法名。配置例子:calculator_test=web.service.xml.rpc.Calculator Calculator类定义如下:package web.service.xml.rpc; public class Calculator {     public int add(int i1, int i2) {            return i1 + i2;    }    public int subtract(int i1, int i2) {            return i1 - i2;    }}
原创粉丝点击