一、引言
- gSOAP是一个OpenSource的web服务开发工具,包括server/client通信和wsdl自动生成功能,能依据wsdl文件生成server和client代码,产生的代码小巧简洁不依赖其他xml解析库,很容易移植,大大减轻webservice程序员的工作量。它提供一种独特的SOAP/XML到C/C++ 语言绑定,以简化C或C++中SOAP/XML Web服务和客户机的开发。gSOAP工具包括一个WSDL生成器,用于为您的 Web 服务生成 Web 服务描述。WSDL importer 工具使SOAP客户机应用程序开发完全自动化。
- gSoap大大简化了使用C/C++开发WEB Service流程,是C/C++开发人员开发WEB服务一种较佳选择。gSoap的安装以及开发文档请参见参考文献[1]、[2]和[3],下面我们主要关注gSoap下Server端接口函数的数据传出。
二、单个传出参数
- gSoap接口函数的返回值只能是int,是soap调用的结果,一般通过soap.error来判断soap的连接情况。接口函数的最后一个参数为传出参数,必须为引用或指针类型(注:传入参数为能为引用类型)。如下所示:
- int ns__add(struct soap *add_soap, int num1, int num2, int *sum);
三、多个传出参数
- 如果需要传出多个参数,需要自己定义一个结构将返回项封装,然后以此结构体作为单个参数传出即可。如下所示:
-
struct type_return{
-
int id;
char *name;
int age;
int ns__getInfo(struct soap *soap, int id, struct type_result *ret); -
int id;
四、二进制数据传出
- 无论是axis c++还是gsoap,对复杂数据类型的支持都不是太好,再加上gsoap的.h文件中不能包含(#include)别的.h文件,可能不能生效,所以需要使用void数据类型,不指明数据类型,返回后再作处理。然而,gsoap不能对void数据类型进行串化(serialize)操作,除非使用union或struct分配实时类型信息。因此,当传出二进行数据时,需要使用xsd__base64Binary结构类型来操作。如下所示:
struct xsd__base64Binary{-
unsigned char *__ptr;
int __size;
在使用上述结构时,可能需要使用soap_malloc()来进行内存分配,并分配__size值。
int ns__demoFunction(struct soap *soap,..., struct xsd__base64Binary *ret)
{-
...
ret->__ptr = (unsigned char *)soap(soap, size); /*size为内存大小*/
ret->__size = size;
memset(ret->__ptr, 0, size);
memcpy(ret->__ptr, src_ptr, size); /*src_ptr为源数据块指针*/
...
return SOAP_OK;
-
unsigned char *__ptr;
五、文件数据传出
- Soap协议支持附件(Attachment),gSoap支持MIME/DIME附件,我们可以使用这个特性来进行整个文件或大量的数据传出。gSoap附件操作与(四)中的二进制数据传出非常相近,同样使用struct xsd__base64Binary类型。这时不再重复,详细可参考文献[2]中的#13 MIME Attachments。
六、参考文献
-
1.
官方网站
2. gSoap User Guide
3. 构建WEB服务C/C++客户机
4. 用C实现WebService
gSoap下Server端接口函数的数据传出[转]
最新推荐文章于 2019-11-29 16:54:36 发布