ASP.NET页面传值(三)--Cookie传值

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;
         }

效果:


注意:当输入文字时会出现乱码,数字则没问题



猜你喜欢

转载自blog.csdn.net/hemingyang97/article/details/81022103