使用XMLHTTP傳送超長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資料提交給伺服器。反過來,資料會保存在伺服器上,直到需要更進一步處理。
當然,處理這個問題可能會有更好的方法。但是當你沒有太多時間的時候,你所需要的就是一個快速的、可用的解決方案。
以上就是使用XMLHTTP發送超長XML表單資料的詳情的內容,更多相關內容請關注PHP中文網(www.php.cn)!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

XML檔可以用PPT開啟嗎? XML,即可擴展標記語言(ExtensibleMarkupLanguage),是一種廣泛應用於資料交換和資料儲存的通用標記語言。與HTML相比,XML更加靈活,能夠定義自己的標籤和資料結構,使得資料的儲存和交換更加方便和統一。而PPT,即PowerPoint,是微軟公司開發的一種用於創建簡報的軟體。它提供了圖文並茂的方

掌握HTTP301狀態碼的意思:網頁重定向的常見應用場景隨著網路的快速發展,人們對網頁互動的要求也越來越高。在網頁設計領域,網頁重定向是一種常見且重要的技術,透過HTTP301狀態碼來實現。本文將探討HTTP301狀態碼的意義以及在網頁重新導向中的常見應用場景。 HTTP301狀態碼是指永久重新導向(PermanentRedirect)。當伺服器接收到客戶端發

HTTP狀態碼200:探索成功回應的意義與用途HTTP狀態碼是用來表示伺服器回應狀態的數字代碼。其中,狀態碼200表示請求已成功被伺服器處理。本文將探討HTTP狀態碼200的具體意義與用途。首先,讓我們來了解HTTP狀態碼的分類。狀態碼分為五個類別,分別是1xx、2xx、3xx、4xx和5xx。其中,2xx表示成功的回應。而200是2xx中最常見的狀態碼

解決方法:1、檢查請求頭中的Content-Type;2、檢查請求體中的資料格式;3、使用適當的編碼格式;4、使用適當的請求方法;5、檢查伺服器端的支援。

使用PHPXML函數處理XML資料:解析XML資料:simplexml_load_file()和simplexml_load_string()載入XML檔案或字串。存取XML資料:利用SimpleXML物件的屬性和方法來取得元素名稱、屬性值和子元素。修改XML資料:使用addChild()和addAttribute()方法新增元素和屬性。序列化XML資料:asXML()方法將SimpleXML物件轉換為XML字串。實戰案例:解析產品饋送XML,提取產品信息,轉換並將其儲存到資料庫中。

如何在C++中實現HTTP流傳輸?使用Boost.Asio和asiohttps客戶端程式庫建立SSL流套接字。連接到伺服器並發送HTTP請求。接收HTTP響應頭並列印它們。接收HTTP回應正文並列印它。

HTTP請求逾時,伺服器端常常會回傳504GatewayTimeout狀態碼。此狀態碼表示伺服器在執行某個請求時,經過一段時間後仍未能取得到請求所需的資源或完成請求的處理。它是5xx系列的狀態碼,表示伺服器端遇到了臨時的問題或過載,導致無法正確處理客戶端的請求。在HTTP協定中,各種狀態碼都有特定的意義和用途,而504狀態碼則用來表示請求逾時問題。在客戶

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲
