Form域中用Post提交容量大的数据

参考:

Form域中用Post提交容量大的数据
http://www.51cto.com 2005-09-14 18:05 出处:PConline <script language="javascript" src="/php/count.php?view=yes&artID=3072" type="text/javascript"></script>
 
 
 

 

以前在工作中遇到一个问题,当表单发送的数据量很大时,就会报错。查阅MSDN了解到,原因是微软对用Request.Form()可接收的最大数据限制为100K字节。

微软建议用Request.BinaryRead()读取表单数据,但由于这种方法读出的是二进制数据,需要对读出的数据逐字节进行分析,生成有意义的字符串(MSDN上的一段程序就是这样写的,但它并没有考虑诸如标点符号等转义字符需要进行特殊分析)。如果说这种方法对于纯英文系统勉强可用的话,则对于中文系统来说就有极大的麻烦,因为汉字是用两个字节表示的,而读出的二进制数据本身并不能判断是英文还是汉字(否则就不是二进制数据,而是字符串了^-^)。这样的话就必须了解汉字的编码规律才能进行分析。最后,即使算法上能把这些都分析出来,大家想想对于一个MB级的巨型字符串逐字节进行分析,其效率何如?所以,此路不通!

不过,办法总是有的。一开始我以为是整个表单数据的总和不能超过100KB,后来发现这是对表单内每个域的限制。问题的解决办法是,对于一个需要发送大数据的域,在提交表单前将数据拆分为小于限额的数份,分别放在数个hidden域中,同时把原有域清空,再正式提交表单。服务器端还是用Request.Form()读取各hidden域的数据,再按照顺序把他们拼接起来就行了。主要代码如下:

注意:需要在Form中的HTML代码内指定一个DIV,以便向其中动态插入hidden域。

====客户端示例代码====

<SCRIPT language=javascript>

//数据拆分,并放到相应的hidden域中,在Form的onSubmit事件中激发

function fnPreHandle()

{

var iCount; //拆分为多少个域

var strData; //原始数据

var iMaxChars = 50000;//考虑到汉字为双字节,域的最大字符数限制为50K

var iBottleNeck = 2000000;//如果文章超过2M字,需要提示用户

var strHTML;//原始数据

strData = frmTest.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++)

{

frmTest.elements["hdnBigField" + i].value = strData.substring((i - 1) * iMaxChars, i * iMaxChars);

}//原数据域清空

frmTest.BigField.value = "";

}

</SCRIPT>



====服务器端示例代码====

<%

Dim strData

Dim intFieldCount

Dim iintFieldCount = Request.Form("hdnCount")For i=1 To intFieldCount

strData = strData & Request.Form("hdnBigfield" & i)

NextResponse.Write strData

%>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Laravel中,你可以使用jQuery来实现AJAX提交表单数据并转跳。首先,在视图文件中添加一个表单,如下所示: ``` <form id="myForm" action="{{ route('submitForm') }}" method="POST"> @csrf <!-- 表单内容 --> <button type="submit" id="submitForm">提交</button> </form> ``` 这里使用了Laravel的路由器来指定表单提交的路由,也就是`submitForm`路由。接下来,你需要编写一个AJAX请求脚本,如下所示: ``` <script> $(document).ready(function(){ $('#submitForm').click(function(e){ e.preventDefault(); $.ajax({ url: "{{ route('submitForm') }}", method: 'POST', data: $('#myForm').serialize(), success: function(response){ window.location.href = "{{ route('redirect') }}"; }, error: function(xhr, status, error){ console.log(error); } }); }); }); </script> ``` 这里使用了jQuery来监听表单提交按钮的点击事件,然后使用AJAX请求将表单数据提交服务器。在成功响应后,我们可以使用`window.location.href`属性来跳转到另一个页面,如上面代码中的`redirect`路由。 最后,你需要在路由文件中定义这两个路由,如下所示: ``` Route::post('/submitForm', 'FormController@submitForm')->name('submitForm'); Route::get('/redirect', 'FormController@redirect')->name('redirect'); ``` 其中,`submitForm`路由用于处理表单提交请求,`redirect`路由用于处理AJAX成功响应后的跳转请求。 希望这可以帮助你实现在Laravel中使用AJAX提交表单数据并转跳。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值