DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> XML學習教程 >> XML詳解 >> 使用XML HTTP發送超長XML表單數據
使用XML HTTP發送超長XML表單數據
編輯:XML詳解     

在把大量的XML作為POST數據的一部分發送給你的IIS服務器的時候——諸如在ASP表單的TEXTAREA裡——你可能會得到一些沒有預料到的結果。當數據在服務器上被處理的時候,由於你處理數據方式的不同,你最終可能會碰到錯誤。其原因是,當你把數據提交回服務器的時候,POST字段裡有一個(數據)大小的限制。這樣做的目的是為了防止可能的入侵者在實施拒絕服務(denial of service,DOS)的攻擊中向服務器發送超大量的數據。

  這一限制也束縛你的能力。但是有辦法解決這個問題。如果你沒被限制在只能夠通過FORM提交來發送數據,那麼你就可以使用XMLHTTP對象(微軟的XML集裡的一個DOM對象)來發送所需要的XML:
 
var oXMLHTTP = new ActiveXObject("Microsoft.XMLHTTP");
oXMLHTTP.open("POST", "XML_handler.ASP", false);
oXMLHTTP.send(XML_to_send);

  由於Request對象會實現IStream接口,所以你可以通過使用DOMDocument對象的load()方法來加載所要提交的XML:
 
Dim oDOM
Set oDOM = Server.CreateObject("MSXML2.DOMDocument")
oDOM.load Request

  如果你被限制在只能夠使用FORM提交,那麼你可以通過提交多個TEXTAREA或者INPUT來跨越這一限制,前面兩者在服務器一接收到這個FORM數據的時候就可以被重新組合在一起:
 
var MAXLEN = 90000;
var oForm = document.createElement("FORM");
oFORM.method = "POST";
oFORM.action = "XML_handler.ASP";
oFORM = document.body.appendChild(oFORM);
var s = document.someForm.txtXML.value;
if (s.length > MAXLEN) {
   while (s.length > MAXLEN) {
     var o = document.createElement("INPUT");
     o.type = "hidden";
     o.name = "txtXML";
     o.value = s.substr(0, MAXLEN);
     oFORM.appendChild(o);
     s = s.substr(MAXLEN);
   }
   var o = document.createElement("INPUT");
   o.type = "hidden";
   o.name = "txtXML";
   o.value = s.substr(0, MAXLEN);
   oFORM.appendChild(o);
} else {
   var o = document.createElement("INPUT");
   o.type = "hidden";
   o.name = "txtXML";
   o.value = s;
   oFORM.appendChild(o);
}


 

這一段代碼會創建一個新的FORM元素,用來處理數據的提交,並將它放置到BODY元素內。然後,它會檢查即將提交給服務器的XML的長度。這個XML駐留在someForm內部一個叫做txtXML的TEXTAREA裡。

  如果這個XML大於90,000字符的MAXLEN,那麼這段代碼就會創建多個隱藏的INPUT(輸入)元素,並把值的屬性設置為90,000個字符的XML數據,或者設置為XML尾部的某個值,從而將這個數據分割成多個部分。如果這個XML的大小小於MAXLEN,那麼這段代碼就只會創建一個INPUT並相應地設置值。然後這個數據就被提交到服務器供處理。

  你可能已經注意到,我把相同的名稱——txtXML——指定給新表單的每個字段。這將有助於把XML數據同其他可能會被提交的數據分隔開來,並為重組XML數據提供了一種簡單的方式。在重組數據的時候,你需要一個簡單的循環來連接字段裡的數據:
 
Dim str, fld
For Each fld In Request.Form("txtXML")
   str = str & fld
Next

  由於已經為每個FORM元素都創建了一個字段集,所以你可以在同一個名稱的字段裡迭代。只要以適當的順序在客戶端創建FORM元素,你就不需要擔心字段被遍歷的順序。通過FORM的appendChild()方法,這能夠被輕易地實現。

  數據在客戶端是按照從左到右、從上到下的順序被提交的,所以當你把INPUT元素附加到FORM元素尾部的時候,在你服務端也總是按照同樣的順序來接收數據的。

  如果你正在尋求實現一個大型的數據解決方案,例如將大量的Excel數據從客戶機器傳遞到服務器上,那麼你就應該重新考慮是否要使用FORM提交,或者將數據從邏輯上分成多個小的部分。由於你無法使用文件類型INPUT元素,所以最具有創造力的解決方案是將數據在本地轉變成為XML,再將XML數據提交給服務器。反過來,數據會保存在服務器上,直到需要更進一步處理。

  當然,處理這個問題可能會有更好的方法。但是當你沒有太多時間的時候,你所需要的就是一個快速的、可用的解決方案。


 

 

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved