前言 本说明示例是gsoap 2.8.15 gsoap工具包中支持的平台是:linux386、macosx、win32,没有提供嵌入式arm平台,本文将指导完成交叉工具编译生成嵌入式平台工具。 工作目录:\\192.168.0.234\work\gaoht\gsoap \gsoap-2.8\ 解压后的目录 \target\ 编译后的安装目录
交叉编译工具:TI平台的:/work/mv_pro_5.0/montavista/pro/devkit/arm/v5t_le/bin/arm_v5t_le-gcc
嵌入式操作系统:linux2.6.18
linux服务器使用Ubantu,内核 linux 2.6.32,IP是192.168.0.234。我的代码都是在服务器上编译的。
在服务器上编译linux386平台工具过程非常简单,不费吹灰之力: ./configure --enable-samples make
第一部分 编译arm平台gsoap工具
1 设置配置参数,同步编译sample目录 make distclean ./configure --host=arm-linux --prefix=/work/gaoht/gsoap/target --enable-samples
2 上述configure执行后会自动生成配置文件gsoap-2.8\config.h,该文件有错误,必须手动修改: #define malloc rpl_malloc --> //#define malloc rpl_malloc 3 修改下列文件,目的是添加头文件#include <malloc.h>,避免编译出错。 gsoap-2.8\gsoap\dom_cpp.cpp gsoap-2.8\gsoap\stdsoap2_cpp.cpp gsoap-2.8\gsoap\stdsoap2_ck_cpp.cpp gsoap-2.8\gsoap\stdsoap2_ssl_cpp.cpp gsoap-2.8\gsoap\wsdl\types.h 4 修改gsoap\src\Makefile,屏蔽这两行,目的是不生成arm平台的soapcpp2可执行文件。 #@rm -f soapcpp2$(EXEEXT) #$(soapcpp2_LINK) $(soapcpp2_OBJECTS) $(soapcpp2_LDADD) $(LIBS) 5 修改gsoap\wsdl\Makefile,屏蔽这两行,目的是不生成arm平台的wsdl2h可执行文件。 #@rm -f wsdl2h$(EXEEXT) #$(wsdl2h_LINK) $(wsdl2h_OBJECTS) $(wsdl2h_LDADD) $(LIBS) 6 完整的make过程需要在linux服务器上运行soapcpp2,因此必须把将soapcpp2复制到gsoap\src\, 同理将wsdl2h复制到gsoap\wsdl。 cp gsoap/bin/linux386/soapcpp2 gsoap/src cp gsoap/bin/linux386/wsdl2h gsoap/wsdl
7 运行 make,完成编译全过程。 make
8 make install 安装后在\\192.168.0.234\work\gaoht\gsoap\target\生成以下目录: \bin \include \lib \share
第二次全部清空编译时可以省略第3步。 完整的步骤: make distclean ./configure --host=arm-linux --prefix=/work/gaoht/gsoap/target --enable-samples cp config--right.h config.h cp gsoap/src/Makefile--right gsoap/src/Makefile cp gsoap/wsdl/Makefile--right gsoap/wsdl/Makefile cp gsoap/bin/linux386/soapcpp2 gsoap/src cp gsoap/bin/linux386/wsdl2h gsoap/wsdl make make install
--------------------------------------------------------- 第二部分 编译过程错误说明
1 不修改gsoap-2.8\config.h,编译会提示: stdsoap2_cpp.cpp:2093: 错误:‘malloc’在此作用域中尚未声明 链接时提示未找到rpl_malloc。
2 不添加头文件#include <malloc.h>,会提示: stdsoap2_cpp.cpp:2093: 错误:‘malloc’在此作用域中尚未声明
3 未修改gsoap\wsdl\Makefile、gsoap\src\Makefile,未拷贝soapcpp2、wsdl2h,编译会提示: ../../gsoap/src/soapcpp2: ../../gsoap/src/soapcpp2:无法执行二进制文件
---------------------------------------------------------
第三部分 gsoap工具使用说明
1 建立工作目录target,将工具wsdl2h、soapcpp2、*.wsdl文件存放在此目录中 2 运行wsdl2h: 运行一般的web service,只要使用/gsoap-2.8/gsoap/ WS-typemap.dat即可。 ./wsdl2h -s -c -o remotediscovery.h remotediscovery.wsdl -t WS-typemap.dat 运行WSDL功能,必须使用/gsoap-2.8/gsoap/WS/ WS-typemap.dat,否则就要手动添加WSDL相关内容。 ./wsdl2h -s -c -o remotediscovery.h remotediscovery.wsdl -t WS-typemap.dat
Gsoap 2.8.15版本下的WS-typemap.dat是完整的,支持WS-Discovery。
Gsoap 2.8.3下的gsoap/typemap.dat需要手工添加命令空间。这个文件不同导致生成的RemoteDiscoveryBinding.nsmap前缀是不同的。
3 运行soapcpp2,用到了/gsoap-2.8/gsoap/import 中的头文件,必须指定import路径。 ./soapcpp2 -c -L -x -I../gsoap-2.8/gsoap/import remotediscovery.h
生成的文件是:
RemoteDiscoveryBinding.nsmap、wsdd.nsmap 这两者是相同的
soapC.c
soapH.h
soapClient.c
soapServer.c
soapStub.h
----------------------------------- ---------------------------------------------------------------------
第六部分 add计算服务 示例运行成功
参考资料 http://blog.csdn.net/myfwf1988/article/details/8899144 1 创建测试目录/work/gaoht/gsoap/gsoap-2.8/gsoap/samples/add, 2 成功编译, 3 在连接0.234的一个终端上运行addserver,绑定端口1234。 ./addserver 1234 4 在连接0.234的另一个终端上运行addclient,指定服务器及端口: ./addclient 192.168.0.234:1234 10 20 5 观察到服务器端提示 Socket connection successful: master socket = 3 Socket connection successful: slave socket = 4 客户端提示: server is 192.168.0.234:1234, num1 is 10, num2 is 20/n--stdsoap2.c: 5027 10 + 20 = 30
|