Asp.Net里的Cookies

来源:http://www.cnblogs.com/shouce/archive/2016/06/07/5565814.html
-Advertisement-
Play Games

什麼是cookies Cookies有很多種,網站上的cookie,瀏覽器的cookie,會話cookie等,cookies是存儲瀏覽器與網站訪問時的數據,是Web伺服器與客戶端連接的方式之一。用戶訪問不同的站點,各個站點會向用戶的瀏覽器發送一個cookie,瀏覽器會分別存儲。實際上,cookies ...


什麼是cookies

    Cookies有很多種,網站上的cookie,瀏覽器的cookie,會話cookie等,cookies是存儲瀏覽器與網站訪問時的數據,是Web伺服器與客戶端連接的方式之一。用戶訪問不同的站點,各個站點會向用戶的瀏覽器發送一個cookie,瀏覽器會分別存儲。實際上,cookies是一小段文本文件,發生在用戶請求和頁面在Web伺服器與瀏覽器之間傳遞。

 

Cookies的用途

    Cookies很多時候被用於身份的驗證、用戶會話識別、購物車的處理。Cookies也可用於把數據從一個網頁傳值到另一個網頁。

 

使用cookies安全嗎?

    使用Cookie安全嗎? 這個問題沒有明確的答案,cookie可能被黑客竊取,獲得受害者的網路賬戶。Cookies不能攜帶病毒也不能在主機電腦上安裝惡意軟體。然而,他們卻可以使用間諜軟體跟蹤用戶網上的瀏覽活動。

 

使用cookies

創建cookie

    有許多的方法創建cookie,我將概述 其中一些比較常用的:

 

方式一:通過使用HttpCookies

複製代碼
        //第一種方式

        HttpCookie TestCookies = new HttpCookie("TestCookies");

        TestCookies.Value = TextBox1.Text;

        TestCookies.Expires = DateTime.Now.AddHours(1);

        Response.Cookies.Add(TestCookies);
複製代碼

方式二:使用Response  

        //第二種方式

        Response.Cookies["TestCookies"].Value = TextBox1.Text;

        Response.Cookies["TestCookies"].Expires = DateTime.Now.AddDays(1);

方式三:把多個值寫入一個cookies

複製代碼
        //把多個值寫入一個cookies中

        Response.Cookies["TestCookies"]["AboutMe"] = TextBox1.Text;

        Response.Cookies["TestCookies"]["SurName"] = "Wen";

        Response.Cookies["TestCookies"]["FirstName"] = "Jianfeng";

        Response.Cookies["TestCookies"]["Sex"] = "Boy";

        Response.Cookies["TestCookies"]["Work"] = "Programmer";

        Response.Cookies["TestCookies"].Expires = DateTime.Now.AddDays(1);
複製代碼

讀取cookie

    在上述代碼中,我已經使用了3種方法來創建cookie,所以,這裡有必要獲取下:

對於方法一:

     string test = Request.Cookies["TestCookies"].Value;

 

對於方法二:

     string test = Request.Cookies["TestCookies"].Value;

 

對於方法三:

複製代碼
     //取出多個值在同一個cookies的方法

     string test;

     test = Request.Cookies["TestCookies"]["AboutMe"];
 
     test= test + ",姓名:" + Request.Cookies["TestCookies"]["SurName"];

     test = test + " " + Request.Cookies["TestCookies"]["FirstName"];

     test = test + ",性別:" + Request.Cookies["TestCookies"]["Sex"];

     test = test + ",職業:" + Request.Cookies["TestCookies"]["Work"];
     Label1.Text
= test;
複製代碼

 

刪除cookie

    在上述代碼中,我已經用了三種方法來創建和讀取cookies。現在看看下麵的代碼將如何刪除cookies

複製代碼
        if (Request.Cookies["TestCookies"] != null)
        {
            Response.Cookies["TestCookies"].Expires = DateTime.Now.AddDays(-1);

            //刷新頁面
            Response.Redirect("TestPage.aspx");
        }
複製代碼

 

瞭解HttpCookies類,它包含了所有的cookie值的集合

    我們不需要使用任何額外的命名空間,只需要引用HttpCookies,因為這個類派生自System.Web命名空間(見第一種方法)。

 

    HttpCookie類有一些常用的屬性:

    • Domain :獲取或設置將此 Cookie 與其關聯的域。
    • Expires :獲取或設置此 Cookie 的過期日期和時間。 
    • HasKeys:獲取一個值,通過該值指示 Cookie 是否具有子鍵。 
    • Name :獲取或設置 Cookie 的名稱。 
    • Path :獲取或設置要與當前 Cookie 一起傳輸的虛擬路徑。 
    • Secure :獲取或設置一個值,該值指示是否使用安全套接字層 (SSL)(即僅通過 HTTPS)傳輸 Cookie 
    • Value :獲取或設置單個 Cookie 值。 
    • Values :獲取單個 Cookie 對象所包含的鍵值對的集合。 

 

Cookie的限制

    使用cookies有以下限制:

1.Cookies最大為4096位元組;

2.只能存儲20cookie,可以使用在一個單一的網站上,如果超過20個,瀏覽器就會丟棄舊的cookies(IE將每個域增至50個);

3.用戶可以改變瀏覽器的設置,以使用或禁用cookies,所以建議檢查用戶的狀態,並提示用戶啟用cookies

 

    有時,用戶在瀏覽器禁用了cookie,而且瀏覽器上也沒有相關的提示信息來提醒啟用cookies。在這種情況下,你需要檢查用戶的瀏覽器,在網站首頁,並顯示相應的提示,或重定向到有這樣提示消息的頁面來提醒用戶。下麵的代碼將檢查用戶的瀏覽器是否支持cookies

複製代碼
    protected void Page_Load(object sender, EventArgs e)
    {
        if (Request.Browser.Cookies)
        {
            //瀏覽器支持cookies,繼續coding......
        }
        else
        {
            //瀏覽器不支持cookies,那麼彈出提示信息或者重定向到新頁面進行處理
        }
    }
複製代碼

 

 

    我建議不要把敏感信息存儲在cookies里,如果有需要的話,就加密下信息吧。

    以上就是cookiesasp.net的使用,歡迎大家一起交流。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 又到周一工作日啦,為了給大家多打點雞血~code4app【iOS weekly】誕生了,從這周開始,每周一,為你推薦整理的上周code4app精華內容,需要的趕快mark下和關註,媽媽再也不用擔心我的學習了~ 【一周精品源碼】各種動畫的集合demo[img]file:///C:\Users\zhan ...
  • 2016-06-0711:05:44 在學習WCF時,學到WCF服務的同步和非同步。 我理解的同步是: 當WCF服務是同步執行時,程式只有一條線程,代碼只能按順序一步一步來執行,當執行客戶端/服務端某方法需要10秒時,只能等待10秒才能接著執行之後的代碼。 當WCF服務是非同步執行時,程式可以同時存在多 ...
  • 記得2010年之前,公司的項目基本上都要用到報表,以前我們常用的方法就是針對客戶的需求來定製化開發(基本上是死寫代碼)來實現,經常導致項目經常性的延期,因為客戶的需求經常會變化,隨著用戶的使用認知度的提高,對報表的要求越來越高,導致程式員不停的修改代碼來實現,效率不高、結束遙遙無期。。。非常的痛苦; ...
  • 前面有一篇博客說到了淘寶UWP的"四核驅動的三維導航—淘寶新UI(需求分析篇)",花了兩周的時間實現了這個框架,然後又陸陸續續用了三周的時間完善它。 多視窗導航,與傳統的導航方式的最大的不同點是: 本篇博客先說一下前三個問題如何解決。 在從頁面A跳到頁面B時,單視窗模式下,很簡單,只要在頁面A中調用 ...
  • 如何在WinForm中請求發送HTTP 手工發送HTTP請求主要是調用 System.Net的HttpWebResponse方法手工發送HTTP的GET請 求: 手工發送HTTP的POST請求 轉自:http://hovertree.com/h/bjaf/i7cux0g6.htm 推薦:http:/ ...
  • 1.RDLC 設計頁面,拖入table或者矩形 2.右擊表格或者矩形單元格,插入--子報表 3.輸入名稱和將此報表用作子報表 名稱:顯示在設計頁面上的,僅作觀看作用 將此報表用作子報表:填寫目錄下的需要作為子報表的RDLC文件的文件名稱(XXX.RDLC),只需要文件名稱不需要.RDLC尾碼名稱。 ...
  • 本篇體驗靜態變數、靜態構造函數和靜態類。 靜態變數 靜態變數位於棧上,它是一個全局變數,在編譯期就已經生成。 public class Cow { public static int count; private int id; public Cow() { id = ++count; } } 客戶 ...
  • 如資料庫中有一個欄位保存了xml格式的一串字元串: <?xml version="1.0" encoding="utf-16"?><ArrayOfPassengerInfoForXml xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xml ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...