Cookie
这个也是大家常使用的方法,Cookie用于在用户浏览器上存储小块的信息,保存用户的相关信息,比如用户访问某网站时用户的ID,用户的偏好等,用户下次访问就可以通过检索获得以前的信息。所以Cookie也可以在页面间传递值。Cookie通过HTTP头在浏览器和服务器之间来回传递的。Cookie只能包含字符串的值,如果想在Cookie存储整数值,那么需要先转换为字符串的形式。
与Session一样,其是什对每一个用户而言的,但是有个本质的区别,即Cookie是存放在客户端的,而session是存放在服务器端的。而且Cookie的使用要配合ASP.NET内置对象Request来使用。
优点:1.使用简单,是保持用户状态的一种非常常用的方法。比如在购物网站中用户跨多个页面表单时可以用它来保持用户状 态。
缺点:1.常常被人认为用来收集用户隐私而遭到批评。
2.安全性不高,容易伪造。
例子:
第一个页面
前台
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="one.aspx.cs" Inherits="AST.NET.one" %>
<!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">
<div>
<asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
<br />
<asp:Button ID="Button1" runat="server" Text="传值" OnClick="Button1_Click" />
</div>
</form>
</body>
</html>
后台
protected void Button1_Click(object sender, EventArgs e)
{
//---Cookie传值
//系统定义HttpCookie类
//HttpCookie("myCookie", TextBox1.Text); 构造函数写法
HttpCookie objCookie = new HttpCookie("myCookie", TextBox1.Text);
// 保存Cookies
Response.Cookies.Add(objCookie);
Response.Redirect("two.aspx");
}
第二个页面
只需添加lable用于接收即可,还需添加using指令(using System.Data;)
protected void Page_Load(object sender, EventArgs e)
{
Label1.Text = Request.Cookies["myCookie"].Value;
}
效果:
注意:当输入文字时会出现乱码,数字则没问题