使用ASP調用WebService時不能以Name為資料庫中的欄位
來源:互聯網
上載者:User
web|資料|資料庫 今天做了一下實驗,發現當WebService返回的XML資料中使用了”Name”關鍵字作為健值時,ASP頁面將無法讀取整個XML文檔,而出現以下錯誤:
無法顯示 XML 頁。
使用 XSL 樣式表無法查看 XML 輸入。請更正錯誤然後單擊 重新整理按鈕,或以後重試。
--------------------------------------------------------------------------------
常值內容中發現無效字元。處理資源 'http://192.168.0.41/aspServer/server.asp' 時出錯。第 56 行,位置: 11
<Name>
//伺服器端ASP代碼如下,WebService代碼略,只要返回一個DataSet的值即可
<%
Set objHTTP = Server.CreateObject("MSXML2.XMLHTTP")
Set xmlDOC =Server.CreateObject("MSXML.DOMDocument")
strWebserviceURL = "http://192.168.0.41/WebService1/Service1.asmx/ds"
'設定參數及其值
'strRequest = "x=2&y=3"
strRequest = "tbname=123"
objHTTP.Open "POST", strWebserviceURL, False
'設定這個Content-Type很重要
objHTTP.SetRequestHeader "Content-Type", "application/x-www-form-urlencoded"
objHTTP.Send(strRequest)
bOK = xmlDOC.load(objHTTP.responseXML)
'看看狀態值
if objHTTP.Status=200 then
xmlStr = xmlDOC.xml
xmlStr = Replace(xmlStr,"<","<",1,-1,1)
xmlStr = Replace(xmlStr,">",">",1,-1,1)
Response.Write xmlStr
else
Response.Write objHTTP.Status&"<br>"
Response.Write objHTTP.StatusText
end if
%>
'關鍵字Name不能用在資料庫設計中!!!!!!!!!!!!
'十萬個注意!!!