前言
本说明示例是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
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
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