中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ASP.NET Cookie對象到底是毛啊?(簡單小例子)

發布時間:2020-06-19 07:43:25 來源:網絡 閱讀:1154 作者:我不會抽煙 欄目:編程語言

記得剛接觸asp.net的時候,就被幾個概念搞的頭痛不已,比如Request,Response,Session和Cookie。然后還各種在搜索引擎搜,各種問同事的,但是結果就是自己還是很懵的節奏。

那cookie到底是毛啊?下面是我最不喜歡的一種解釋方式(官方定義吧應該叫,我這種智商根本讀不懂嘛~)

Cookie對象也稱緩存對象,該對象用于保存客戶端瀏覽器請求的服務器頁面,也可用它存放非敏感性的用戶信息。

以前根本讀不懂啊,現在其實也懵懵的。

還是用例子能把這個概念搞明白

1、做一個用戶登錄的界面,用cookies保存登錄信息的功能。如圖:

ASP.NET Cookie對象到底是毛啊?(簡單小例子)

后臺代碼:

        protected void Page_Load(object sender, EventArgs e)
        {
            if (Request.Cookies["password"] != null)
            {
                if (DateTime.Now.CompareTo(Request.Cookies["password"].Expires) > 0)
                {
                    textbox_password.Text = Request.Cookies["password"].Value;
                }
            }
        }
        protected void button_login_Click(object sender, EventArgs e)
        {
            if (checkbox_remember.Checked)
            {
                HttpCookie cookie_password = new HttpCookie("password");
                cookie_password.Value = textbox_password.Text;
                Response.Cookies.Add(cookie_password);

                DateTime dtNow = DateTime.Now;
                TimeSpan ts = new TimeSpan(0, 0, 0, 10);//這里是將cookie的有效期設置成10s
                cookie_password.Expires = dtNow.Add(ts);
            } 
        }

這個例子很簡單,思路就是選擇記住密碼的checkbox,就創建一個cookie用于記錄密碼的內容,同時設置有效期。當下次加載的時候,判斷有沒有這個“密碼”cookie,有的話判斷這個cookie是否過期,若未過期,就將這個cookie里存的值取出來,放到對應的文本框中。

這里把有效期設置為10s的原因是為了讓大家看到的效果明顯些。大家只要不斷的去刷新頁面,就會發現在10s之前,密碼部分還是一直有值,過了10s,就自動清空了。這就是因為cookie到期。

2、一個統計當前IP登錄頁面次數的功能。界面如圖:

ASP.NET Cookie對象到底是毛啊?(簡單小例子)

其實還是這個例子比較有意思,界面很簡單,但是問題稍多。

后臺代碼:

        string ipAddress = string.Empty;
        protected void Page_Load(object sender, EventArgs e)
        {
            ipAddress = Dns.GetHostByName(Server.MachineName.ToString()).AddressList[0].ToString();
            if (!IsPostBack)
            {
                if (Request.Cookies.AllKeys.Contains(ipAddress))
                {
                    //Request.Cookies[ipAddress].Value = (Convert.ToInt32(Request.Cookies[ipAddress].Value) + 1).ToString();@@@
                    HttpCookie cookie_ip = new HttpCookie(ipAddress);
                    cookie_ip.Value = (Convert.ToInt32(Request.Cookies[ipAddress].Value) + 1).ToString();
                    Response.Cookies.Set(cookie_ip);
                }
                else
                {
                    HttpCookie cookie_ip = new HttpCookie(ipAddress);    
                    cookie_ip.Value = "1";
                    Response.Cookies.Add(cookie_ip);
                    DateTime dtNow = DateTime.Now;
                    TimeSpan ts = new TimeSpan(0, 0, 0, 20);
                    cookie_ip.Expires = dtNow.Add(ts);
                }
            }
        }
        protected void button_statistics_Click(object sender, EventArgs e)
        {
            if (Request.Cookies[ipAddress] != null)
            {
                textbox_count.Text = Request.Cookies[ipAddress].Value;
            }
            else
            {
                textbox_count.Text = "0";
            }
        }

        protected void button_clear_Click(object sender, EventArgs e)
        {
            HttpCookie cookie_ip = new HttpCookie(ipAddress);
            cookie_ip.Expires = DateTime.Now.AddDays(-1);
            Response.Cookies.Set(cookie_ip);
            Request.Cookies.Remove(ipAddress);
            Request.Cookies.Clear();
        }

這個小例子的思路就是,先獲得本地的IP地址,這就保證了添加Cookie的時候,給Cookie了一個獨一無二的key。在刷新頁面的時候,去判斷當前所有Cookie中是否存在一個同名的cookie。如果不存在,就新建一個cookie,當然,此cookie的key=IP地址。就是Page_Load里else的部分。如果存在,那么就在原來的值的基礎上加1。這里要注意修改已存在Cookie值的寫法。

最開始的時候我用的是注釋掉的@@@這行代碼,就是正常思路,看著也沒什么問題呀,不過這樣寫不行,第一次加載之后的每次加載,取到的Request.Cookies[ipAddress].Value這個值總是1。所以對于修改已有的cookie值,還是需要使用cookies的set方法才行。

此外還有一個地方是需要注意的,就是刪除cookie的時候,如果直接使用Cookies.Remove或者Cookies.Clear()方法都達不到想要的效果。需要配合的加上Expires,給一個負值。然后去更新Cookie,再刪除,這樣這個cookie就徹底消失了。否則在下次加載的時候又會出現,這個還真不知道是為什么?我之前就寫了一句Request.Cookies.Clear(),打斷點跟的時候,所有的cookie確實都清空了,但是當再次加載的時候,在添加cookie前打了斷點,會發現之前刪除的cookie又出現了。很奇怪啊~~

希望明白的朋友告訴一聲怎么回事哈。

兩個簡單的小例子讓自己對cookie不再感覺那么陌生和害怕了。所以光看概念還是效果一般,動手才是王道呀~


新浪微博:http://weibo.com/zhouhongyu1989 歡迎圍觀~!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彩票| 右玉县| 治多县| 望谟县| 乌拉特前旗| 邹城市| 安乡县| 博客| 民权县| 桦南县| 日土县| 榆社县| 洱源县| 台中县| 富裕县| 禹城市| 天等县| 兴宁市| 阳春市| 广水市| 安顺市| 肇庆市| 上虞市| 常州市| 和林格尔县| 泰和县| 盘山县| 洛隆县| 洛宁县| 湟中县| 湘乡市| 鄂温| 罗定市| 鞍山市| 上蔡县| 闽侯县| 隆德县| 宁都县| 聂荣县| 正宁县| 吉林省|