Asp.Net页面传值的方法简单总结【】

4418040-cc878d6e1f8e102a

1、QueryString

当页面上form按照get的方式向页面发送请求数据的时候,web server会将请求数据放入

一个QEURY_STRING的环境变量中,然后通过QeueryString方法从这个变量中获取相应的参数。

例如:

发送参数页面Test1.aspx 按钮单击代码:

string url = "Test2.aspx?id="+ txtId.Text;

Response.Redirect(url);

接收参数页面 Test2.aspx

后台代码获取:string id=Request.QueryString["id"];

优点:使用比较简单

缺点:安全性低,参数直接暴露在url上,并且不能传递对象。

2、Session

把需要传的值放在Session变量中,然后在另外一个变量中使用它,session存放在服务器端,

在Session变量中存储过多的变量,会消耗较多的服务器资源,所以要及时清理不需要的Session变量。

优点:能传递复杂对象,数据量大小不限制

缺点:作为全局变量,容易误操作。

用法:

Session["id"]= txtId.Text;

在接收页面调用:string id=Session["id"].ToString();

3、Application

Application在整个应用程序生命周期都是有效的,类似于使用全局变量,是所有的用户

共用的全局变量,session是单个用户独有的全局变量,Application一般用于记录用户

信息、统计在线人数等。

用法:

Application.Lock();

Application["id"]= txtId.Text;

Server.Transfer("Test2.aspx");

Application.UnLock();

在接收页面调用:string id=Application["id"].ToString();

4、Cookie

Cookie主要用于客户端保存用户的信息,比如登录信息,它通过HTTP头传递信息,只能

包含字符串的值,通过Request对象的Cookie集合可以获得浏览器所有的Cookie。

优点:使用简单,可以减轻服务器的负担,通过Cookie来保存用户的登录状态,实现记住

用户登录的功能。

缺点:被认为用来收集用户隐私而遭到批评,也可能被别人篡改、伪造登录信息。

用法:

Test1.aspx 按钮单击代码:

HttpCookie name =new HttpCookie("name1");

HttpCookieage = new HttpCookie("age1");

name.Value = txtName.Text;

age.Value = txtAge.Text;

Response.Cookies.Add(name);

Response.Cookies.Add(age);

Server.Transfer("Test2.aspx");

Test2.aspx 按钮单击代码:

TextBox1.Text = "姓名是:" +Request.Cookies["name1"].Value.ToString() + "年龄是:" +Request.Cookies["age1"].Value.ToString();

5、Server.Transfer

Server.Transfer 是一个很奇特的方法。当使用 Server.Transfer 方法重定向页面时,

虽然页面也会被重定向至指定页,但是并不会在浏览器的URL上体现出来,并且若重定

向的页面后有参数,也不会显示在浏览器的URL上。

优点:直接在服务器端重定向,使用简单方便,减少了客户端对服务器端提出请求;

缺点:客户端浏览器中的URL地址是不改变,会导致在新的页面可能出现一些意想不到的问题。

比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的

图片、超链接都会导致错误的指向。可以传递各种数据类型的值和控件的值。

来源:我的公众号

原文地址:https://www.cnblogs.com/hgmyz/p/12352813.html