首頁  >  文章  >  後端開發  >  使用XMLHTTP傳送超長XML表單資料的詳情

使用XMLHTTP傳送超長XML表單資料的詳情

黄舟
黄舟原創
2017-03-04 17:24:471299瀏覽

在把大量的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資料提交給伺服器。反過來,資料會保存在伺服器上,直到需要更進一步處理。

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

 以上就是使用XMLHTTP發送超長XML表單資料的詳情的內容,更多相關內容請關注PHP中文網(www.php.cn)!


#
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn