程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> ASP編程 >> 關於ASP編程 >> asp下對POST提交數據限制的解決方法

asp下對POST提交數據限制的解決方法

編輯:關於ASP編程
    問題的解決辦法是,對於一個需要發送大數據的域,在提交表單前將數據拆分為小於限額的數份,分別放在數個hidden域中,同時把原有域清空,再正式提交表單。服務器端還是用Request.Form()讀取各hidden域的數據,再按照順序把他們拼接起來就行了。主要代碼如下:

注意:需要在Form中的HTML代碼內指定一個DIV,以便向其中動態插入hidden域。

====客戶端示例代碼====

在Form中的HTML代碼內加入:<div id=divHidden></div>,在Form標簽中加入: onSubmit="return fnPreHandle(this)",將下面代碼中的BigField換成您表單中提交大數據庫的域的名稱。
JavaScript代碼
復制代碼 代碼如下:
<script language=javascript>     
//數據拆分,並放到相應的hidden域中,在Form的onSubmit事件中激發     
function fnPreHandle(MyForm)     
{     
var iCount; //拆分為多少個域     
var strData; //原始數據     
var iMaxChars = 50000;//考慮到漢字為雙字節,域的最大字符數限制為50K     
var iBottleNeck = 2000000;//如果文章超過2M字,需要提示用戶     
var strHTML;     

//原始數據     
strData = MyForm.BigField.value;     

//如果文章實在太長,需要提醒用戶     
if (strData.length > iBottleNeck)     
{     
if (confirm("您要發布的文章太長,建議您拆分為幾部分分別發布。\n如果您堅持提交,注意需要較長時間才能提交成功。\n\n是否堅持提交?") == false)     
return false;     
}     

iCount = parseInt(strData.length / iMaxChars) + 1;     

//hdnCount記錄原數據域拆分為多少個子域     
strHTML = "<input type=hidden name=hdnCount value=" + iCount + ">";     

//生成各子域的HTML代碼     
for (var i = 1; i <= iCount; i++)     
{     
strHTML = strHTML + "\n" + "<input type=hidden name=hdnBigField" + i + ">";     
}     

//在Form中DIV(divHidden)內動態插入各hidden域的HTML代碼     
document.all.divHidden.innerHTML = strHTML;     

//給各子域賦值     
for (var i = 1; i <= iCount; i++)     
{     
MyForm.elements["hdnBigField" + i].value = strData.substring((i - 1) * iMaxChars, i * iMaxChars);     
}     

//原數據域清空     
MyForm.BigField.value = "";     
}     
</script> 

服務器端示例代碼ASP/Visual Basic代碼
復制代碼 代碼如下:
<%     
Dim strData     
Dim intFieldCount     
Dim i     

intFieldCount = Request.Form("hdnCount")     

For i=1 To intFieldCount     
strData = strData & Request.Form("hdnBigfield" & i)     
Next     

Response.Write strData     
%>    

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved