Asp.Net页面间传值常见的几种方法

一、QueryString

  QueryString是一种非常简单的传值方式,他是将传送的值显示在浏览器的地址栏中。如果是传递一个或多个安全性要求不高或是结构简单的数值时,可以使用这个方法。但是对于传递数组或对象的话,就不能用这个方法了。

    优点:1.使用简单,对于安全性要求不高时传递数字或是文本值非常有效。
    缺点:1.缺乏安全性,由于它的值暴露在浏览器的URL地址中的。
       2.不能传递对象。

列子:

a.aspx

  protected void Button1_Click(object sender, EventArgs e)
{
string url;
string id = "";
string name = "demo";
url = "b.aspx?Id=" + id + "&name=" + name + "";
Response.Redirect(url);
}

b.aspx前台接收

<!DOCTYPE html>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title></title>
</head>
<body>
<form id="form1" runat="server">
<%
string Id = Request["Id"];
string name = Request["name"];
%>
Id:<%=Id%>
姓名:<%=name%>
</form>
</body>
</html>

二、session

  想必这个肯定是大家使用中最常见的用法了,作用于用户个人,所以,过量的存储会导致服务器内存资源的耗尽。

    优点:1.使用简单,不仅能传递简单数据类型,还能传递对象。
       2.数据量大小是不限制的。

    缺点:1.在Session变量存储大量的数据会消耗较多的服务器资源。

       2.容易丢失。

列子:

a.aspx中创建Session并且赋值

     protected void Button1_Click(object sender, EventArgs e)//a.aspx中创建Session
{
string name = "name";//定义一个变量并赋值
Session["name"]=name;//给session赋值
}

b.aspx获取a.aspx中创建的Session的值

    protected void Button1_Click(object sender, EventArgs e)//b.asxp中获取a.aspx中创建的Session
{
string name = Session["name"].ToString();//获取session中键为name的值
Session.Remove("name");//移除session中键为name的值
}

三、Cookie

  这个也是大家常使用的方法,Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。

    优点:1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状态。

    缺点:1.常常被人认为用来收集用户隐私而遭到批评。

       2.安全性不高,容易伪造。

例子:

a.aspx中创建Cookie并且赋值,设置Cookie过期时间

        protected void Button1_Click(object sender, EventArgs e)//a.aspx中创建cookie并赋值
{
HttpCookie cookie = new HttpCookie("login");
cookie.Values["username"] = "wx";
cookie.Values["password"] = "";
cookie.Expires = System.DateTime.Now.AddDays();//设置过期时间 1天
Response.Cookies.Add(cookie);
}

b.aspx获取a.aspx中创建Cookie

        protected void Button1_Click(object sender, EventArgs e)//b.aspx获取a.aspx中保存的cookie
{
string name = Request.Cookies["login"]["username"];
string password = Request.Cookies["login"]["password"];
}

四、Application

  Application对象的作用范围是整个全局,也就是说对所有用户都有效。它在整个应用程序生命周期中都是有效的,类似于使用全局变量一样,所以可以在不同页面中对它进行存取。它和Session变量的区别在于,前者是所有的用户共用的全局变量,后者是各个用户独有的全局变量。一般用在网站访问人数

    优点:1.使用简单,消耗较少的服务器资源。

       2.不仅能传递简单数据,还能传递对象。

       3.数据量大小是不限制的。

    缺点:1.作为全局变量容易被误操作。所以单个用户使用的变量一般不能用application。

例子

a.aspx中创建Application并赋值

        protected void Button1_Click(object sender, EventArgs e)//a.aspx中创建Application并赋值
{
string name = "wx";
Application["Name"] = name;
}

b.aspx中获取a.aspx中创建的Application

        protected void Button1_Click(object sender, EventArgs e)//b.aspx中获取a.aspx中创建Application
{
string name = Application["Name"].ToString();
}

五、Server.Transfer

  Server.Transfer是从当前的ASPX页面转到新的ASPX页面,服务器端执行新页并输出,在新页面中通过Context.Handler来获得前一个页面传递的各种数据类型的值、表单数据、QueryString.由于重定向完全在服务器端完成,所以客户端浏览器中的URL地址是不会改变的。调用Server.Transfer时,当前的ASPX页面终止执行,执行流程转入另一个ASPX页面,但新的ASPX页面仍使用前一ASPX页面创建的应答流。

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

       2.可以传递各种数据类型的值和控件的值。

    缺点:1.客户端浏览器中的URL地址是不改变,会导致在新的页面可能出现一些意想不到的问题。比如如果源页面和目的页面不在同一个虚拟目录或其子目录下,那么使用相对路径的图片、超链接都会导致错误的指向。

列子

a.aspx中创建Server.Transfer并赋值

        protected void Button1_Click(object sender, EventArgs e)//a.aspx中创建Server.Transfer并赋值
{
Server.Transfer("b.aspx?id=1&name=wx");
}

b.aspx获取a.aspx中创建的Server.Transfer

       protected void Page_Load(object sender, EventArgs e)
{
string id = Request["id"];
string name = Request["name"];
}
上一篇:mongo语句优化分析


下一篇:动手写一个简单的Web框架(HelloWorld的实现)