PB通過Post調用的web Service心得體會


大概分為三部走:

第一步:
拿到webSerivce地址:
http://www.webxml.com.cn/WebServices/WeatherWebService.asmx

使用第三方的工具知道具體協議:

第二部 Soup 需要在代碼里面拼接單數占位變量

第三步 比較核心的異步 就是post調用webservice時候需要的需要傳入 SoupAction 更具更具生成的

原理 WebService=>http=>socket

MainInvok
`String inaddr,intype,indata,indata1,outdata

inaddr='http://www.webxml.com.cn/WebServices/WeatherWebService.asmx'

intype='上海'

indata='<soap:Envelope xmlns:soap="http://www.w3.org/2003/05/soap-envelope" xmlns:web="http://WebXml.com.cn/">'&
+'soap:Header/'&
+'soap:Body'&
+'web:getSupportCity'&
+'web:byProvinceName'+intype+'</web:byProvinceName>'&
+'</web:getSupportCity>'&
+'</soap:Body>'&
+'</soap:Envelope>'

outdata=tools.Post(inaddr,indata,'POST','application/soap+xml',false,'getSupportCity')

MessageBox('調用交易返回',outdata) `

tools.Post 方法實現
`string outdata= space(40000)
//定義對象
OleObject lole_tenyear

lole_tenyear = CREATE OleObject

//這里創建對的時候沒有時候需要安裝msxml
lole_tenyear.ConnectToNewObject("Microsoft.XMLHttp")

lole_tenyear.Open (inmethod,inadrr,inasy); //false 同步 true 異步

if inchangjing='getSupportCity' then
lole_tenyear.setRequestHeader ("SOAPAction", 'http://WebXml.com.cn/getSupportCity')
end if
if inchangjing='getSupportProvince' then
lole_tenyear.setRequestHeader ("SOAPAction", 'http://WebXml.com.cn/getSupportProvince')
end if
//這里請求的核心 借助工具
lole_tenyear.setRequestHeader ("Content-Type", intype)

//ljson.getformatjson('')
lole_tenyear.setRequestHeader('Content-Length',String(Len(indata)))

//ljson.getformatjson('')
lole_tenyear.Send (indata)

do While lole_tenyear.readyState <> 4 // ' 查詢狀態,延時
if(lole_tenyear.readyState=0) Then
outdata= '調用交易返回請求未初始化還沒有調用 open()'
end if
if(lole_tenyear.readyState=1) Then
outdata= '調用交易返回請求已經建立,但是還沒有發送還沒有調用 send()'
end if
//3:請求在處理中;通常響應中已有部分數據可用了,但是服務器還沒有完成響應的生成。
//4:響應已完成;您可以獲取並使用服務器的響應了。
Loop

outdata='調用交易返回'+lole_tenyear.responseText
If lole_tenyear.Status >= 300 Then

//100 Continue 初始的請求已經接受,客戶應當繼續發送請求的其余部分
//101 Switching Protocols 服務器將遵從客戶的請求轉換到另外一種協議
//200 OK 一切正常,對GET和POST請求的應答文檔跟在后面。
//201 Created 服務器已經創建了文檔,Location頭給出了它的URL。
//202 Accepted 已經接受請求,但處理尚未完成。
//203 Non-Authoritative Information 文檔已經正常地返回,但一些應答頭可能不正確,因為使用的是文檔的拷貝
//204 No Content 沒有新文檔,瀏覽器應該繼續顯示原來的文檔。如果用戶定期地刷新頁面,而Servlet可以確定用戶文檔足夠新,這個狀態代碼是很有用的
//205 Reset Content 沒有新的內容,但瀏覽器應該重置它所顯示的內容。用來強制瀏覽器清除表單輸入內容
//206 Partial Content 客戶發送了一個帶有Range頭的GET請求,服務器完成了它
//300 Multiple Choices 客戶請求的文檔可以在多個位置找到,這些位置已經在返回的文檔內列出。如果服務器要提出優先選擇,則應該在Location應答頭指明。
//301 Moved Permanently 客戶請求的文檔在其他地方,新的URL在Location頭中給出,瀏覽器應該自動地訪問新的URL。
//302 Found 類似於301,但新的URL應該被視為臨時性的替代,而不是永久性的。
//303 See Other 類似於301/302,不同之處在於,如果原來的請求是POST,Location頭指定的重定向目標文檔應該通過GET提取
//304 Not Modified 客戶端有緩沖的文檔並發出了一個條件性的請求(一般是提供If-Modified-Since頭表示客戶只想比指定日期更新的文檔)。服務器告訴客戶,原來緩沖的文檔還可以繼續使用。
//305 Use Proxy 客戶請求的文檔應該通過Location頭所指明的代理服務器提取
//307 Temporary Redirect 和302(Found)相同。許多瀏覽器會錯誤地響應302應答進行重定向,即使原來的請求是POST,即使它實際上只能在POST請求的應答是303時才能重定向。由於這個原因,HTTP 1.1新增了307,以便更加清除地區分幾個狀態代碼:當出現303應答時,瀏覽器可以跟隨重定向的GET和POST請求;如果是307應答,則瀏覽器只能跟隨對GET請求的重定向。
//400 Bad Request 請求出現語法錯誤。
//401 Unauthorized 客戶試圖未經授權訪問受密碼保護的頁面。應答中會包含一個WWW-Authenticate頭,瀏覽器據此顯示用戶名字/密碼對話框,然后在填寫合適的Authorization頭后再次發出請求。
//403 Forbidden 資源不可用。
//404 Not Found 無法找到指定位置的資源
//405 Method Not Allowed 請求方法(GET、POST、HEAD、DELETE、PUT、TRACE等)對指定的資源不適用。
//406 Not Acceptable 指定的資源已經找到,但它的MIME類型和客戶在Accpet頭中所指定的不兼容
//407 Proxy Authentication Required 類似於401,表示客戶必須先經過代理服務器的授權。
//408 Request Timeout 在服務器許可的等待時間內,客戶一直沒有發出任何請求。客戶可以在以后重復同一請求。
//409 Conflict 通常和PUT請求有關。由於請求和資源的當前狀態相沖突,因此請求不能成功。
//410 Gone 所請求的文檔已經不再可用,而且服務器不知道應該重定向到哪一個地址。它和404的不同在於,返回407表示文檔永久地離開了指定的位置,而404表示由於未知的原因文檔不可用。
//411 Length Required 服務器不能處理請求,除非客戶發送一個Content-Length頭。
//412 Precondition Failed 請求頭中指定的一些前提條件失敗
//413 Request Entity Too Large 目標文檔的大小超過服務器當前願意處理的大小。如果服務器認為自己能夠稍后再處理該請求,則應該提供一個Retry-After頭
//414 Request URI Too Long URI太長
//416 Requested Range Not Satisfiable 服務器不能滿足客戶在請求中指定的Range頭
//500 Internal Server Error 服務器遇到了意料不到的情況,不能完成客戶的請求
//501 Not Implemented 服務器不支持實現請求所需要的功能。例如,客戶發出了一個服務器不支持的PUT請求
//502 Bad Gateway 服務器作為網關或者代理時,為了完成請求訪問下一個服務器,但該服務器返回了非法的應答
//503 Service Unavailable 服務器由於維護或者負載過重未能應答。例如,Servlet可能在連接池已滿的情況下返回503。服務器返回503時可以提供一個Retry-After頭
//504 Gateway Timeout 由作為代理或網關的服務器使用,表示不能及時地從遠程服務器獲得應答
//505 HTTP Version Not Supported 服務器不支持請求中所指明的HTTP版本
outdata='HTTP request failed:'+lole_tenyear.responseText
End If

DESTROY lole_tenyear
return outdata`


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM