gSOAP的主頁是:
http://sourceforge.net/projects/gsoap2
下載解壓后,可以在gsoap\bin\win32里 找到wsdl2h.exe和soapcpp2.exe(另外還有linux和mac版本)。
wsdl2h.exe的作用是根據WSDL生成C/C++風格的頭 文件
soapcpp2.exe的作用是根據頭文件自動生成調用遠程 SOAP服務的客戶端代碼(稱為存根:Stub)和提供SOAP服務的框架代碼(稱為框架:Skeleton),另外它也能從頭文件生成WSDL文件。
gsoap\stdsoap2.cpp則是gSOAP的核心代碼,要使用 gSOAP只要在項目里包含這個文件以及由soapcpp2.exe生成的代碼即可。另外還有個stdsoap2.c,內容與stdsoap2.cpp一 模一樣,用于純C項目。
gSOAP兩大工具的用法
從WSDL中產生頭文件
用法:

wsdl2h常用選項
- -o 文件名,指定輸出頭文件
- -n 名空間前綴 代替默認的ns
- -c 產生純C代碼,否則是C++代碼
- -s 不要使用STL代碼
- -t 文件名,指定type map文件,默認為typemap.dat
- -e 禁止為enum成員加上名空間前綴
type map文件用于指定SOAP/XML中的類型與C/C++之間的轉換規則,比如在wsmap.dat里寫

那么SOAP/XML中的string將轉換成std::wstring或wchar_t*,這樣能更好地支持中文。
例:



從http://www.ayandy.com/Service.asmx?WSDL 生成ayandy.h文件,名空間為ay,使用wsmap.dat指定的轉換規則。
wsdl2h生成的頭文件里的變量、類型等名稱的前面都會加上名空間前綴,以兩個下劃線分隔。如上面的命令生成的頭文件,有這樣的定義:










前面的ayandy1__的是名空間前綴,用以防止名稱沖突。 wsdl2h的-n選項可以改變這個名空間前綴(默認為ns)。對于枚舉ay1__theDayFlagEnum內 的成員,如果嫌它太長的話,可以用-e命令選項禁止加入名空間前綴。


編寫SOAP程序除了頭文件是不夠的,還要有連接、通信、XML解析、序列/反序列化等工作。gSOAP提供的socapcpp2.exe就 是用于從頭文件中生成這些代碼的,我們只要關心真正的業務邏輯就行了。
用法:
soapcpp2 頭文件

例:
soapcpp2 ayandy.h

將生成下面這些文件
- soapStub.h // soap的存根文件,定義了ayandy.h里對應的遠程調用模型
- soapC.c soapH.h // soap的序列和反序列代碼,它已經包含了soapStub.h,服務器端與客戶端都要包含它
- soapClient.c soapClientLib.c // 客戶端代碼,soapClientLib.c文件則只是簡單地包含soapClient.c和soapC.c
- soapServer.c soapServerLib.c // 服務器端代碼,soapServerLib.c文件則只是簡單地包含soapServer.c和soapC.c
- ServiceSoap.nsmap ServiceSoap12.nsmap // 名空間定義,服務器端與客戶端都要包含它
- soapServiceSoapProxy.h soapServiceSoap12Proxy.h // 客戶端的C++簡單包裝(如果頭文件是純C代碼,這兩個文件就不會生成)
綜上所述
- 如果編寫服務器端,項目里應該加入soapServerLib.c,代碼里包含頭文件soapH.h
- 如果編寫客戶端,項目里應該加入soapClientLib.c,代碼里包含頭文件SoapH.h(或xxxxProxy.h)
- 當然,還要加入gsoap庫里的stdsoap2.cpp文件(如果是寫C代碼,則加入stdsoap2.c)
如果看到soapcpp2提示:”Critical error: #import: Cannot open file "stlvector.h" for reading.“, 那是因為我們的頭文件使用了STL(wsdl2h 沒用-s選項),這時要使用-I選項指定gSOAP的 import文件路徑,這個路徑是"$gsoap\gsoap\import":
soapcpp2 ayandy.h -I D:\gsoap-2.7\gsoap\import

soapcpp2常用選項
- -C 僅生成客戶端代碼
- -S 僅生成服務器端代碼
- -L 不要產生soapClientLib.c和soapServerLib.c文件
- -c 產生純C代碼,否則是C++代碼(與頭文件有關)
- -I 指定import路徑(見上文)
- -x 不要產生XML示例文件
- -i 生成C++包裝,客戶端為xxxxProxy.h(.cpp),服務器端為xxxxService.h(.cpp)。
編寫SOAP客戶端
下面將演示使用gSOAP到網上取得天氣預報,互聯網上有不少網站提供SOAP服務,比如Google提供的搜索API(現在已不再提 供新的License Key了),不少博客提供的API等。這里介紹一個提供天氣預報服務的SOAP服務,地址是http://www.ayandy.com
它提供了三個函數:
getSupportCity 查詢本天氣WebService支持的城市信息。
getSupportProvince 查詢本天氣 WebService支持的省份信息。
getWeatherbyCityName 根據城市名稱獲得天 氣情況。
它的WSDL地址是http://www.ayandy.com/Service.asmx?WSDL
現在,我們編寫一個客戶端去調用getWeatherbyCityName來 取得天氣情況
1. 從WSDL得到頭文件
wsdl2h -o ayandy.h http://www.ayandy.com/Service.asmx?WSDL

2. 從頭文件得到存根(Stub)源文件
soapcpp2 -i -C -x ayandy.h -ID:\gsoap-2.7\gsoap\import

