gSoap下Server端接口函数的数据传出[转]

一、引言

    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);

四、二进制数据传出

    无 论是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;
    }

五、文件数据传出

    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

转于
http://hi.baidu.com/songfeng163/blog/item/89ac27f7a3578f20720eecf3.html

你可能感兴趣的:(struct,server,webservice,SOAP,web服务,OpenSource)