Form Post提交容量大的数据

微软建议用Request.BinaryRead()读取表单数据,但由于这种方法读出的是二进制数据,需要对读出的数据逐字节进行分析,生成有意义的字符串(MSDN上的一段程序就是这样写的,但它并没有考虑诸如标点符号等转义字符需要进行特殊分析)。如果说这种方法对于纯英文系统勉强可用的话,则对于中文系统来说就有极大的麻烦,因为汉字是用两个字节表示的,而读出的二进制数据本身并不能判断是英文还是汉字(否则就不是二进制数据,而是字符串了^-^)。这样的话就必须了解汉字的编码规律才能进行分析。最后,即使算法上能把这些都分析出来,大家想想对于一个MB级的巨型字符串逐字节进行分析,其效率何如?所以,此路不通!
  不过,办法总是有的。一开始我以为是整个表单数据的总和不能超过100KB,后来发现这是对表单内每个域的限制。问题的解决办法是,对于一个需要发送大数据的域,在提交表单前将数据拆分为小于限额的数份,分别放在数个hidden域中,同时把原有域清空,再正式提交表单。服务器端还是用Request.Form()读取各hidden域的数据,再按照顺序把他们拼接起来就行了。主要代码如下:
  注意:需要在Form中的HTML代码内指定一个DIV,以便向其中动态插入hidden域。
  ====客户端示例代码====
  
复制代码 代码如下:



  ====服务器端示例代码====
  
复制代码 代码如下:

<%
  Dim strData
  Dim intFieldCount
  Dim iintFieldCount = Request.Form("hdnCount")For i=1 To intFieldCount
  strData = strData & Request.Form("hdnBigfield" & i)
  NextResponse.Write strData
  %>

你可能感兴趣的:(Form Post提交容量大的数据)