`
fanrey
  • 浏览: 255003 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

xml-rpc实践(cc)

 
阅读更多
xml-rpc规范:
http://xmlrpc.scripting.com/spec.html

下文转载自(没有亲自试):
http://blog.csdn.net/fm6060/article/details/5906627

xml-rpc实践

用了两天的时间做了一个简单的xml-rpc的测试,这个例子里server用java实现,client分别用java和c实现
1.装备java包和c的.h(include)、.so(lib)
(1)在 http://ws.apache.org/xmlrpc/ 下载java server及client最新版本的jar包(apache-xmlrpc-current-bin.zip)
(2)需到 http://jakarta.apache.org/commons/index.html 下载如下程序包: commons-codec-1.3
(通用编码 / 解码算法实现,可参考 http://www.devx.com/Java/Article/29795/1954?pf=true 或 http://jakarta.apache.org/commons/codec/userguide.html 来获得该软件包的详细信息)
commons-httpclient-3.0.1 ( HTTP 协议的客户端编程工具包,详细介绍见 http://www-128.ibm.com/developerworks/cn/opensource/os-httpclient/ )
(3)http://xmlrpc-c.sourceforge.net/下载xmlrpc-c-1.06.41.tgz,该包需要到linux下安装,安装方法如下:
A、在/tmp/用tar -zxvf xmlrpc-c-1.06.41.tgz命令解压缩后,进入到解开的目录中,
B、#./configure
C、#make
D、#make install
相关库文件会拷贝到/usr/local/lib下,头文件会拷贝到/usr/loca/include下。

(4)从curl.haxx.se下载最新版的curl库(如curl-7.21.1.tar.gz)
同上执行解压
安装的步骤也同上
B、#./configure
C、#make
D、#make install

2.建立server
(1)新建类 Calcloator
package xml.test;

public class Calcloator {

public int add(int i1, int i2) {
  System.out.println ("###########");
        return i1 + i2;
    }

    public int subtract(int i1, int i2) {
        return i1 - i2;
    }

}


(2)建立类AreaServer
package xml.test;

import org.apache.xmlrpc.common.TypeConverterFactoryImpl;
import org.apache.xmlrpc.server.PropertyHandlerMapping;
import org.apache.xmlrpc.server.XmlRpcServer;
import org.apache.xmlrpc.server.XmlRpcServerConfigImpl;
import org.apache.xmlrpc.webserver.WebServer;
import java.io.IOException;

public class AreaServer {
 
public static void main(String[] args) {
   try{
    startServer();
   }catch(Exception e){
   e.printStackTrace();
     }

    }


public static void startServer() throws Exception{
  System.out.println("begin start ");
 
  WebServer server = new WebServer(8081);
  XmlRpcServer xmlRpcServer = server.getXmlRpcServer();
  System.out.println("aaaaaa "); 
  PropertyHandlerMapping phm = new PropertyHandlerMapping();
  phm.addHandler("Calcloator",Calcloator.class);
 
  xmlRpcServer.setHandlerMapping(phm);

  XmlRpcServerConfigImpl serverConfig = (XmlRpcServerConfigImpl) xmlRpcServer.getConfig();
        serverConfig.setEnabledForExtensions(true);
        serverConfig.setContentLengthOptional(false); 
 
 
        server.start();
}
}

调用AreaServer启动server

3、java的client
package test;
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 ClientTest {

public static void main(String[] args) throws Exception {
        XmlRpcClientConfigImpl config = new XmlRpcClientConfigImpl();
        config.setServerURL(new URL("http://localhost:8081/"));
        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("Calcloator.subtract", params);
        System.out.println("2 + 3 = " + result);
     
        // make a call using dynamic proxy
      

}
}
每一次调用client都会执行server的指定方法

4、c的client
#include<iostream>
#include<fstream>
using namespace std;
#include<xmlrpc-c/base.h>
#include<xmlrpc-c/client.h>
#define NAME "Xmlrpc-c Test Client"
#define VERSION "1.0.0.0"
void die_if_fault(xmlrpc_env* const envP)
{
        if(envP->fault_occurred)
        {  
                cout<<"xml-rpc fault:"<<envP->fault_string<<" code:"<<envP->fault_code<<endl;
                exit(1);
        }  
}
int main(int argc, char* argv[])
{
       cout<< "aaaaa"<<endl;
        xmlrpc_env env;
        xmlrpc_value* resultP;
        xmlrpc_int32 sum,x;
        const char* const serverUrl = "http://192.168.177.193:8081/";
        const char* const methodName = "Calcloator.add";
        cout << "aaaaa"<<endl;
        xmlrpc_env_init(&env);
        cout << "11111"<<endl;       
        xmlrpc_client_init2(&env,XMLRPC_CLIENT_NO_FLAGS,NAME,VERSION,NULL,0);
        cout << "22222"<<endl;               
        die_if_fault(&env);
        cout << "33333"<<endl;                       
        resultP = xmlrpc_client_call(&env,serverUrl,methodName,"(ii)",(xmlrpc_int32)atoi(argv[1]),(xmlrpc_int32)atoi(argv[2]));
        cout << "bbbb" <<endl;
        die_if_fault(&env);
        cout << "ccccc" <<endl;       
        //xmlrpc_read_int(&env,resultP,&sum);
        //xmlrpc_decompose_value(&env,resultP,"(ii)",&sum);
     xmlrpc_read_int(&env, resultP, &sum);       
        cout << "ddddd" <<endl;       
               
        die_if_fault(&env);
        cout<<"sum:"<<sum<<endl;
        cout<<"x:"<<x<<endl;
       
        xmlrpc_DECREF(resultP);
        xmlrpc_env_clean(&env);
        xmlrpc_client_cleanup();
       
        return 0;
}


编译命令
g++ -g xmlrpcclienttest.c -lxmlrpc_client -lpthread  -lxmlrpc -lxmlrpc_xmlparse -lxmlrpc_xmltok -o aa.o
(这明明是个c的程序,变成c++是因为之前用gcc无论如何都编译不过去)
执行 ./aa.o 1 2
如果提提示找不到路径则
#export LD_LIBRARY_PATH=/usr/local/lib

分享到:
评论

相关推荐

    LabVIEW XML-RPC

    LabVIEW XML-RPC 是一种基于XML的远程过程调用(RPC)技术,它允许LabVIEW应用程序与其他支持XML-RPC协议的系统进行通信。这个技术在跨平台交互和分布式系统开发中发挥着重要作用,使得LabVIEW可以与不同编程语言...

    xml-rpc学习心得

    ### XML-RPC学习心得 #### 一、XML-RPC简介 XML-RPC(XML Remote Procedure Call)是一种轻量级的远程过程调用协议,它使用XML来编码调用数据,并通过HTTP进行传输。XML-RPC使得运行在不同操作系统上的应用程序...

    3.0 XML-RPC 官方示例+源码+官网地址资料.rar

    在3.0版本中,XML-RPC进一步提升了性能和安全性,使其成为分布式应用程序之间交互的一种实用方式。 XML-RPC的核心思想是简单:一个客户端通过发送一个包含方法名和参数的XML文档到服务器,服务器解析这个请求,执行...

    Apache的XML-RPC简化你的WebService应用

    XML-RPC利用XML作为数据交换格式,提供了简单、跨平台的RPC解决方案,极大地简化了Web Service的应用开发。这篇博文将深入探讨Apache XML-RPC的原理、使用方法以及它如何简化Web Service应用的构建。 XML-RPC的核心...

    使用 XML-RPC 为 C++ 应用程序启用 Web 服务

    **使用 XML-RPC 为 C++ 应用程序启用 Web 服务** 随着互联网的普及,越来越多的开发人员和 IT 部门开始考虑将复杂的 C++ 业务和科学应用程序迁移到基于 Web 的环境。Web 服务协议如 SOAP、REST 和 XML-RPC 提供了将...

    Apache xml-rpc入门

    ### Apache XML-RPC 入门知识点详解 #### 一、XML-RPC 概念与应用场景 **XML-RPC(XML Remote Procedure Call)**是一种轻量级的远程过程调用协议,它允许在不同操作系统和语言环境之间进行数据交换。XML-RPC 使用...

    XML-RPC.rar_HTTP协议_XML-R_XML-RPC _xml rpc

    简单介绍了XML-RPC这种通过HTTP协议进行RPC通信的规范。 以Apache XML-RPC 3.0为基础,对XML-RPC的基本原理及Apache XML-RPC 3.0的主要特性进行了讨论和分析

    XML-RPC客户端程序

    XML-RPC客户端测试程序 向XMLRPC服务器发送一个XML-RPC请求,以文本文件读取xml文件; 记录返回的数据到文件中; windows命令行程序,使用前请配置*.pln文件 askcyg@hotmail.com

    apache XML-RPC

    Apache XML-RPC(XML Remote Procedure Call)是一种基于XML的远程过程调用协议,它允许不同的计算机之间通过网络进行通信,仿佛它们之间的函数调用一样。这个技术被广泛应用于分布式系统和跨平台通信,尤其是在Java...

    xml-rpc.net.2.1.0.rar

    在.NET环境中,`xml-rpc.net.2.1.0`库提供了一个方便的实现,使开发者能够轻松地构建XML-RPC客户端和服务端应用程序。 XML-RPC的核心概念是将方法调用转换为HTTP请求,并使用XML格式传输参数和返回值。这种简单的...

    xml-rpc协议资料

    ### XML-RPC协议详解 #### 一、XML-RPC简介 **XML-RPC**(XML Remote Procedure Call)是一种轻量级的远程过程调用协议,它允许不同操作系统、不同环境中的程序通过Internet进行通信。XML-RPC使用HTTP作为传输协议...

    delphi与JSP通过xml-rpc协议交换数据的例子.rar_delphi XML_delphi jsp_delphi rp

    XML-RPC(XML Remote Procedure Call)是一种基于XML的远程过程调用协议,它允许不同的编程语言和操作系统之间进行跨平台的数据交换和远程方法调用。本示例是关于如何在Delphi环境中通过XML-RPC与Java JSP应用程序...

    xml_rpc需要的jar包

    在Java环境中,XML-RPC的实现通常依赖于一些特定的库,如Apache XML-RPC项目提供的组件。在你给出的文件信息中,"xml_rpc"的标签以及提到的三个jar包,揭示了这个压缩包包含的是XML-RPC所需的基础库。 1. **commons...

    基于XML-RPC和PHP5的WEB服务的研究与实现.pdf

    XML-RPC是一种远程过程调用(RPC)协议,它允许不同的Web服务之间进行交互。PHP5是一种流行的 сервер-side脚本语言,可以用于开发Web服务。 Web服务是一种提供某种功能的程序代码,可以实现不同Web服务之间的...

    xml-rpc.net.2.4.0.zip

    Version 2.4.0 has been released: xml-rpc.net.2.4.0.zip New feature and fixed issues: New StructParams property on XmlRpcMethodAttribute which provides supports for APIs which use a struct to ...

    java delphi 互相调用 xml-rpc实例

    XML-RPC(XML Remote Procedure Call)是一种轻量级的远程过程调用协议,它允许不同编程语言编写的系统之间进行通信。在这个实例中,我们将探讨如何使用XML-RPC实现Java与Delphi之间的互相调用,以及提供的源码和可...

    XML-RPC 实现C++和C#交互.docx

    【XML-RPC 实现C++和C#交互】 XML-RPC(XML Remote Procedure Call)是一种简单、轻量级的远程过程调用协议,允许不同编程语言编写的应用程序之间进行通信。这种技术基于HTTP协议,使用XML来编码调用的参数和返回...

    [其他类别]xml-rpc协议 2.2_xmlrpc-2.2.zip

    在"xml-rpc-2.2.zip"这个压缩包中,可能包含的是XML-RPC协议2.2版本的相关资料和库文件,用于理解和应用XML-RPC技术。 XML-RPC的基本工作原理是这样的: 1. **请求构造**:客户端将方法名和参数封装成一个XML文档...

    XML-RPC实现WebService示例InterFace程序.rar

    目前进行Web Service通信有两种协议标准,一种是XML-RPC,另外一种是SOAP。XML-RPC比较简单,出现时间比较早,SOAP比较复杂,主要是一些需要稳定、健壮、安全并且复杂交互的时候使用。 PHP中集成了XML-RPC和SOAP两种...

    Android使用XML-RPC实现blog客户端源码

    在Android开发中,XML-RPC库可以帮助开发者实现客户端与服务器之间的通信,比如发布博客、获取博客列表等操作。本项目是一个Android应用,它演示了如何使用XML-RPC技术实现对CSDN博客的客户端功能。 1. **Android...

Global site tag (gtag.js) - Google Analytics