下面是转载的一篇文章,在ubuntu下试验成功。转自:http://bbs.php100.com/apps.php?q=diary&uid=56398&a=detail&did=1265
服务端实现步骤:
1. 创建socket套接字,并在某个端口打开;
2. 定义并注册服务端方法;
3. 运行服务端。
客户端实现步骤:
1. 调用服务端注册的方法;
2. 处理返回信息。
如下为一个XmlRpc的代码实现:
#######
server.h
#######
#ifndef SERVER_H_
#define SERVER_H_
#include <xmlrpc-c/base.hpp>
#include <xmlrpc-c/registry.hpp>
#include <xmlrpc-c/server_abyss.hpp>
class XmlrpcServer
{
private:
class MyTestMethod: public xmlrpc_c::method
{
public:
MyTestMethod()
{
this->_signature = "A:ii";
this->_help = "This method adds two integers together";
}
void execute(xmlrpc_c::paramList const& paramList,xmlrpc_c::value * const retval)
{
const int addend(paramList.getInt(0));
const int adder(paramList.getInt(1));
*retval = (xmlrpc_c::value_int)(addend+adder);
}
};
private:
xmlrpc_c::registry addIntRegistry;
xmlrpc_c::serverAbyss* AbyssServer;
int port;
int socket_fd;
public:
void regester_xml_method();
int setupServer();
int setupSocket();
public:
XmlrpcServer(int _port):port(_port),socket_fd(-1){};
};
#endif
#######
server.cpp
#######
#include "server.h"
#include <xmlrpc-c/base.hpp>
#include <xmlrpc-c/registry.hpp>
#include <xmlrpc-c/server_abyss.hpp>
#include <sys/signal.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netinet/tcp.h>
#include <unistd.h>
#include <fcntl.h>
#include <string.h>
#include <cstring>
#include <iostream>
using namespace std;
void XmlrpcServer::regester_xml_method()
{
xmlrpc_c::methodPtr add_int(new XmlrpcServer::MyTestMethod);
addIntRegistry.addMethod("add.int",add_int);
}
int XmlrpcServer::setupServer()
{
AbyssServer = new xmlrpc_c::serverAbyss(xmlrpc_c::serverAbyss::constrOpt()
.registryP(&addIntRegistry).socketFd(socket_fd));
cout<< "Xmlrpc server is running......"<< endl;
AbyssServer->run();
cout<< "Xmlrpc server stopped"<< endl;
return 0;
}
int XmlrpcServer::setupSocket()
{
int rc;
int yes = 1;
struct sockaddr_in rm_addr;
socket_fd = socket(AF_INET, SOCK_STREAM, 0);
if (-1 == socket_fd)
{
cout<< "Can not open server socket: " << endl;
return -1;
}
rc = setsockopt(socket_fd, SOL_SOCKET, SO_REUSEADDR, &yes, sizeof(int));
if (-1 == rc)
{
cout << "Can not set socket options: " <<endl;
close(socket_fd);
return -1;
}
rm_addr.sin_family = AF_INET;
rm_addr.sin_port = htons(port);
rm_addr.sin_addr.s_addr = INADDR_ANY;
rc = bind(socket_fd,(struct sockaddr *) &(rm_addr),sizeof(struct sockaddr));
if (-1 == rc)
{
cout << "Can not bind to port " << port <<endl;
close(socket_fd);
return -1;
}
return 0;
}
##########
serverMain.cpp
##########
#include "server.h"
#include <iostream>
using namespace std;
int main(void)
{
XmlrpcServer myServer(2655);
if(myServer.setupSocket() != 0)
return -1;
myServer.regester_xml_method();
if(myServer.setupServer() != 0)
{
cout<< "cannot setup RPC Server"<< endl;
return -1;
}
return 0;
}
########
clientMain.cpp
########
#include <xmlrpc-c/base.hpp>
#include <xmlrpc-c/client_simple.hpp>
#include <iostream>
#include <stdlib.h>
using namespace std;
int main(int argc,char **argv)
{
int a,b,int_result;
xmlrpc_c::value result;
if(argc != 3)
{
cout<< "please input Two interger numbers: "<< endl;
cin >>a >>b;
}
else
{
a = atoi((argv[1]));
b = atoi((argv[2]));
}
xmlrpc_c::clientSimple myClient;
myClient.call("http://localhost:2655/RPC2","add.int","ii",&result,a,b);
int_result = (xmlrpc_c::value_int)(result);
cout<< "sum of " <<a<<" and "<< b<< " is " << int_result<< endl;
return 0;
}
用gcc编译器编译,编译命令为:
服务端:
gcc -Wall -g server.cpp serverMain.cpp -o server.deamon -lstdc++ -lxmlrpc++ -lxmlrpc_server_abyss++ -lxmlrpc_server
客户端:
gcc -g -Wall -o add_int clientMain.cpp -lstdc++ -lxmlrpc_client++
测试:
可执行文件生成成功后,运行 " ./server.deamon "
然后执行 " ./add_int 1 2 " 得输出结果:sum of 1 and 2 is 3
执行 ./add_int 1456 456465 3
please input Two interger numbers:
4 9
sum of 4 and 9 is 13
运行成功!
分享到:
相关推荐
xmlrpc远程函数式服务调用,C++作为服务端,python、C++客户端通过http进行调用,远程调用函数式服务,具体运行结果可以参考https://blog.csdn.net/zckui/article/details/121147756 博客
linux 下 c++ 写的xmlrpc ,示例很全面.
在这个场景中,我们关注的是如何利用XMLRPC实现在PHP和C++之间的通信。XMLRPC通过将方法调用和参数编码为XML消息,然后通过HTTP传递,服务器解码后执行相应操作并返回结果。 首先,我们需要了解XMLRPC的基本结构。...
相对于SOAP,XMLRPC更轻量级,不需要复杂的WSDL文档,因此在某些场景下,XMLRPC可能更易于实现和部署。 从提供的压缩包文件名“xmlrpc-c-1.06.32”来看,这可能是XMLRPC-C的一个版本,一个用C语言编写的XMLRPC库。...
总的来说,`go-xmlrpc`库是Golang开发者在处理XMLRPC通信时的一个强大工具,它简化了XMLRPC服务端和客户端的实现,提高了开发效率,同时也保证了代码的可读性和维护性。通过深入理解和使用这个库,你可以轻松地在...
`Zend`是一个PHP开发框架,其中包含了一个强大的XMLRPC扩展,可以方便地实现XMLRPC服务端和客户端的功能。在`Zend Framework`中,我们可以使用`Zend_XmlRpc_Server`创建服务端,定义处理函数;使用`Zend_XmlRpc_...
这个"xmlrpc demo"是一个示例项目,包含服务端和客户端的实现,是学习XMLRPC入门的良好起点。 在服务端,XMLRPC服务器通常会监听一个特定的HTTP端口,等待来自客户端的请求。当请求到来时,服务器解析XML数据,识别...
标签"xmlrpc xmlrpc_java xmlrpc_s xmlrpc-2.0.1.jar zip"进一步强调了这个资源与Java语言的XMLRPC库、XMLRPC服务(xmlrpc_s可能指代服务端组件)以及对应的jar文件相关,同时指出文件是以zip格式打包的。...
例如,它可以用于控制远程设备、实现客户端和服务端之间的数据同步,或者构建可扩展的网络应用程序。 7. **安全考虑**:虽然XMLRPC提供了一种简单的方式来调用远程服务,但它的安全性依赖于传输层的安全措施,如...
例如,一个基于Web的应用可能需要与后台数据库服务器进行通信,这时就可以使用XMLRPC来实现客户端和服务器之间的数据交换。开发者可以通过XMLRPC库轻松地在各种编程语言中实现远程调用,如Python、PHP、Java、C++等...
在Java环境中,XMLRPC库是一个常用的选择,可以方便地实现客户端和服务端的通信。 本教程主要围绕以下几个知识点展开: 1. **XMLRPC的基本概念**: - XMLRPC的核心思想是通过XML来封装参数和返回值,然后通过HTTP...
在Python中,XMLRPC提供了一种轻量级的跨平台解决方案,用于实现服务器和客户端之间的交互。 在给定的文件列表中,我们可以看到以下三个关键文件: 1. server.py:这是一个XMLRPC服务器的实现。Python的`xmlrpc....
在"Ub.XMLRPC"这个项目中,开发者可能已经实现了服务器端的XMLRPC服务,以及客户端如何调用这些服务的示例代码。这些代码可以帮助我们理解XMLRPC的工作原理,以及如何在C#中进行实现。通过分析和学习这些代码,我们...
XMLRPC的核心思想是使用HTTP作为传输协议,XML作为数据交换格式,实现客户端和服务器之间的通信。这种设计使得XMLRPC具有跨平台、跨语言的特性,可以在各种操作系统和编程语言中无缝集成。 ### XMLRPC的工作流程 1...
这个框架使得开发者可以轻松地在Java应用中实现客户端和服务器端的交互,而无需关心底层的网络细节。 XMLRPC的核心概念是通过XML来封装方法名和参数,然后将封装后的XML数据作为HTTP请求的主体发送给服务器。服务器...
在这个场景中,我们使用XML-RPC来实现C++和C#之间的交互,其中C#作为客户端,C++作为服务器端。 ### XML-RPC 基本原理 XML-RPC的核心思想是通过HTTP协议传输XML编码的函数调用和返回值。XML文档包含了方法名、参数...
这个库提供客户端和服务端API,使得开发人员能够轻松地实现远程方法调用。 - 你可以从官方网站或者其他可靠的源下载XML-RPC库,然后将其引入到你的项目中。 3. **服务端实现**: - 创建一个实现了XML-RPC服务器端...
在.NET环境中,XMLRPC.NET接口提供了一种实现XMLRPC客户端和服务端的方法,使得开发者能够轻松地创建能够与其他系统进行交互的应用程序。 XMLRPC.NET接口的核心概念包括以下几点: 1. **请求与响应**:XMLRPC通信...
在这个"XmlRpcClient.rar"压缩包中,包含的主要内容是关于在Visual C++环境下实现XMLRPC客户端的代码示例。 "XmlRpcClient.cpp"文件很可能是实现XMLRPC客户端功能的核心源代码。在C++中,开发XMLRPC客户端通常涉及...