文档章节

页面间参数传递问题

aminqiao
 aminqiao
发布于 2014/06/09 14:20
字数 675
阅读 309
收藏 0

ASP.NET应用程序前台与后台的数据交换都是通过FORM表单来完成的,FORM表单提供了两种数据传输方式:GET和POST,这个两种数据传输方 式在实际传输中有很大的不同,但ASP.NET框架中已经屏蔽了二者的一些差异。GET是用来从服务器上获得数据,而POST是用来向服务器提交数据的。 二者数据传输过程中分别对应了HTTP协议中的GET和POST方法。

    GET方式是把参数数据队列加到提交表单的ACTION属性所指的URL后面,并且使用"?"隔开,值和表单内各个字段一一对应,在URL中可以看到,它是FROM默认的提交方式,受URL长度的限制,它所能传递的数据量小。
    POST方式是把表单中的数据放在FORM载体中,按照变量和值相对应的方式,传递到ACTION所指向URL,POST可以传递大数据量的信息到服务器,通常文件上传就是使用POST方式上传。

    为解决GET方式传递大数据量参数的问题,要使用POST方式进行数据提交,下面是一个用来代替window.open的方法
1.JavaScript

/*
 * PostNewWin
 * Author:ppchen
 
*/
var PostNewWin = function(url){
    
var urlArr = url.split("?");
    
var postUrl = urlArr[0];
    
var postData = urlArr[1];
    
var iframe = document.getElementById("postData_iframe");
    
if(!iframe){
        iframe 
= document.createElement("iframe");
        iframe.id 
= "postData_iframe";
        iframe.scr
= "about:blank";
        iframe.frameborder 
= "0";
        iframe.style.width 
= "0px";
        iframe.style.height 
= "0px";
        
        
var form = document.createElement("form");
        form.id 
= "postData_form";
        form.method 
= "post";
        form.target 
= "_blank";
        
        document.body.appendChild(iframe);
        iframe.contentWindow.document.write(
"<body>" + form.outerHTML + "</body>");
    }
    iframe.contentWindow.document.getElementById(
"postData_form").innerHTML = "<input name='postData' id='postData' type='text' value='" + postData + "'/>";
    iframe.contentWindow.document.getElementById(
"postData_form").action = postUrl;
    iframe.contentWindow.document.getElementById(
"postData_form").submit();
};

 
2.CSharp

/// <summary>
/// 从Form中取得参数
/// Author:ppchen
/// </summary>
/// <returns>参数集合</returns>
private NameValueCollection ParseFormData()
{
    NameValueCollection sQueryString 
= new NameValueCollection();
    
if (this.Request.Form.Count > 0 && this.Request.Form["postData"!= null)
    {
        
string sPostData = this.Request.Form["postData"].ToString();
        sPostData 
= sPostData.Trim(new char[] { '&'' ' });
        
if (!string.IsNullOrEmpty(sPostData))
        {
            
string[] sParameterList = sPostData.Split('&');
            
for (int i = 0; i < sParameterList.Length; i++)
            {
                
string[] sParameter = sParameterList[i].Split('=');
                
for (int j = 0; j < sParameter.Length; j = j + 2)
                {
                    sQueryString.Add(sParameter[j], HttpUtility.UrlDecode(sParameter[j 
+ 1]));
                }
            }
        }
    }
    
return sQueryString;
}


通过以上的JS代码在客户端打开页面,通过以上的CS代码在服务端取得参数,这样使用了POST方式解决了GET方式中URL的长度限制,可以传递大数据量的参数了:)


乱码问题

比如ajax请求的url="searchPeoBySomeWords.do?KeyWord="+obj.value;我们需要用escape函数来将中文参数“包装”两下,看清楚是两下,不是一下。url="searchPeoBySomeWords.do?KeyWord="+escape(escape(obj.value))。 那么这样“包装”后我们如何在action中来解码了,不要急,一个java方法就能解决问题(代码如Escape.java)。action中我们只要 用Escape.java中的unescape静态方法就可解码。String keyWord = Escape.unescape(request.getParameter("KeyWord")).trim();原来拆开"包装"后,依然是我们可爱的中文。

本文转载自:

共有 人打赏支持
aminqiao
粉丝 8
博文 30
码字总数 1305
作品 0
广州
私信 提问
Vue 页面状态保持页面间数据传输的一种方法

如果大家觉得有用,更多的模块请点击查看 vue router给我们提供了两种页面间传递参数的方式: 动态路由匹配 编程式的导航 下面介绍一下vue-viewplus 一个简化Vue应用开发的工具库中的参数栈模...

赵津
10/31
0
0
springmvc - 关于Controller中方法参数类型的几点注意

简单类型 1、当controller方法中的参数类型为基本数据类型时。如果页面提交过来的数据为null或"",会出现数据转换的异常。 2、当controller方法中的参数类型为基本数据类型的包装类型时,页面传...

中柠檬
2016/12/10
14
0
Spring3.0_MVC中解决提交表单时产生的中文乱码的方法

在spring3.0_MVC 框架中,通过JSP页面、HTML页面提交表单时,表单的参数传递到对应的servlet后会出现中文显示乱码的问题。解决办法可采用spring自带的过滤技术,对所有页面间参数的传递设置统...

空云万里晴
2012/03/29
0
0
ionic3三种跳转方法对应的页面间数据传递

1.将数据传递到要跳转到的页面 (1)push() 要将新页面推送到堆栈,可使用push方法。同时也可以通过将数据传递给push方法的第二个参数,来将数据传递给下一个页面。 (2)[navParams]属性: ...

神奇的小卷毛
2017/10/23
0
0
JS解析URL参数并返回JSON格式

背景 有时候,简单的参数只需要两个页面间传递,无需后台加工,这个时候,就可以考虑使用页面间传参方式 方案 采用JS中location.search获取传递的参数 优势 1、直接传递2、无依赖3、主流浏览...

沫沫金
01/05
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Eos测试框架EosFactory

EOS Factory包含一个完整的EOS测试框架,可以进行智能合约的开发和测试。由Tokenika于创建于2017年的这个基于Python的EOS测试框架可以轻松地完成智能合约的开发、部署与测试。 如果你希望马上...

汇智网教程
5分钟前
0
0
CompletableFuture get方法一直阻塞或抛出TimeoutException

问题描述 最近刚刚上线的服务突然抛出大量的TimeoutException,查询后发现是使用了CompletableFuture,并且在执行future.get(5, TimeUnit.SECONDS);时抛出了TimeoutException异常,导致接口响...

xiaolyuh
31分钟前
1
0
dubbo 搭建与使用

官网:http://dubbo.apache.org/en-us/ 一,安装监控中心(可以不安装) admin管理控制台,monitor监控中心 下载 bubbo ops 这个是新版的,需要node.js环境,我没有就用老版的了...

小兵胖胖
34分钟前
2
0
mac 下 mysql 8.0.13 安装并记录遇到的问题 以便以后查看

安装 官网mysql 下载地址 安装过程 省去 安装好之后 下载navicat 错误1 链接 遇到 mysql 2003 - Can't connect to MySQL server 错误, 解决方案 重启mysql 服务 #错误2 ERROR 1045: Acces...

杭州-IT攻城狮
昨天
5
0

中国龙-扬科
昨天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部