如何處理ASP .NET Core中的cookie?
譯文
【51CTO.com快譯】cookie是通常用于存儲有關(guān)用戶信息的一條數(shù)據(jù),存儲在用戶的計算機上。在大多數(shù)瀏覽器中,每個cookie都存儲為一個小文件,但在Firefox中,它們一起存儲在一個文件中。 cookie表示為鍵值對,你可以利用鍵來讀取、寫入或刪除cookie。
ASP.NET Core使用cookie來維護會話狀態(tài)。包含會話ID的cookie隨每個請求一起發(fā)送到客戶端。本文討論了如何處理ASP.NET Core中的cookie。
若要使用本文提供的代碼示例,你應(yīng)該在系統(tǒng)中安裝Visual Studio 2019。如果還沒有一份,可以在此處下載Visual Studio 2019(https://visualstudio.microsoft.com/downloads/)。
在Visual Studio中創(chuàng)建ASP.NET Core MVC項目
先不妨在Visual Studio 2019中創(chuàng)建一個ASP.NET Core MVC項目。假設(shè)系統(tǒng)中已安裝Visual Studio 2019,請按照以下概述的步驟,在Visual Studio中創(chuàng)建一個新的ASP.NET Core MVC項目。
- 啟動Visual Studio IDE。
- 點擊“創(chuàng)建新項目”。
- 在“創(chuàng)建新項目”窗口中,從顯示的模板列表中選擇“ASP.NET Core Web應(yīng)用程序”。
- 點擊“下一步”。
- 在“配置新項目”窗口中,指定新項目的名稱和位置。
- 可選情況下,選中“將解決方案和項目放在同一個目錄中”復(fù)選框。
- 點擊“創(chuàng)建”。
- 在接下來顯示的“創(chuàng)建新的ASP.NET Core Web應(yīng)用程序”窗口中,從頂部下拉列表中選擇.NET Core作為運行時環(huán)境,并選擇ASP.NET Core 2.2(或更高版本)。
- 選擇“Web應(yīng)用程序(Model-View-Controller)”作為項目模板,以創(chuàng)建新的ASP.NET Core MVC應(yīng)用程序。
- 確保“啟用Docker支持”和“配置HTTPS”這兩個復(fù)選框未勾選,因為我們在這里不會使用這些功能。
- 確保“身份驗證”設(shè)置為“不進行身份驗證”,因為我們在這里也不會使用身份驗證。
- 點擊“創(chuàng)建”。
現(xiàn)在,你應(yīng)該已經(jīng)準(zhǔn)備好在Visual Studio中使用一個新的ASP.NET Core MVC項目。我們將在本文的后續(xù)部分使用該項目。
在ASP.NET Core中讀取cookie
你可以從Request.cookies集合讀取cookie。下面的代表片段說明了如何從ASP.NET Core中的Request對象讀取cookie。
- string cookie = Request.Cookies["Key"];
如果你想指定cookie的到期失效時間,可以使用Append方法的重載版本,如下面給出的代碼片段所示。
- CookieOptions option = new CookieOptions();
- option.Expires = DateTime.Now.AddMilliseconds(10);
- Response.Cookies.Append(key, value, option);
cookieOptions類使你可以在創(chuàng)建cookie時指定以下額外屬性:
- 域—用于指定與cookie有關(guān)的域
- 到期失效時間—用于指定cookie的到期失效時間
- 路徑—用于指定cookie路徑
- 安全策略—用于指定cookie是否可以通過HTTPS來訪問
- HttpOnly—用于指定cookie是否僅對服務(wù)器可用
在ASP.NET Core中寫入cookie
想寫入cookie,你可以利用與Request對象有關(guān)的Append方法。以下代碼片段說明了如何做到這一點。
- Response.Cookies.Append(somekey, somevalue);
在ASP.NET Core中刪除cookie
若要刪除cookie,可以使用與Request對象有關(guān)的cookies集合的Delete方法。以下代碼片段說明了如何做到這一點。
- Response.Cookies.Delete(somekey);
在ASP.NET Core中訪問HttpContext
在本節(jié)中,我們將介紹如何在ASP.NET Core中處理cookie數(shù)據(jù)。我們需要訪問HttpContext才能訪問Request對象。你可以使用IHttpContextAccessor接口,訪問ASP.NET Core中的HttpContext。HttpContextAccessor類實現(xiàn)該接口。
首先,你應(yīng)該注冊IHttpContextAccessor用于依賴項注入。以下代碼片段說明了如何在Startup類的ConfigureServices方法中添加類型HttpContextAccessor的單一服務(wù)。
- public void ConfigureServices(IServiceCollection services)
- {
- services.AddSingleton
- HttpContextAccessor>();
- //Other code
- }
你可以利用依賴項注入來獲得IHttpContextAccessor實例的引用。這將反過來為你提供HttpContext的引用。
以下代碼片段說明了如何訪問控制器中的IHttpContextAccessor實例。請注意,當(dāng)你在Visual Studio中創(chuàng)建新的ASP.NET Core MVC項目后,默認(rèn)情況下將創(chuàng)建HomeController。
- public class HomeController : Controller
- {
- private readonly IHttpContextAccessor _httpContextAccessor;
- public HomeController(IHttpContextAccessor httpContextAccessor)
- {
- this._httpContextAccessor = httpContextAccessor;
- }
- //Write your action methods here
- }
在ASP.NET Core控制器方法中寫入cookie數(shù)據(jù)
你可以使用以下方法在控制器中寫入cookie數(shù)據(jù)。
- public IActionResult Write(string key, string value, bool isPersistent)
- {
- CookieOptions options = new CookieOptions();
- if (isPersistent)
- options.Expires = DateTime.Now.AddDays(1);
- else
- options.Expires = DateTime.Now.AddSeconds(10);
- _httpContextAccessor.HttpContext.Response.Cookies.Append
- (key, value, options);
- return View("WriteCookie");
- }
在ASP.NET Core控制器方法中讀取cookie數(shù)據(jù)
一旦cookie數(shù)據(jù)成功寫入,可以使用以下方法在控制器中讀取cookie數(shù)據(jù)。
- public IActionResult Read(string key)
- {
- ViewBag.Data =
- _httpContextAccessor.HttpContext.Request.Cookies[key];
- return View("ReadCookie");
- }
要檢查cookie是否已正確寫入,可以查看Web瀏覽器的cookie緩存。
原文標(biāo)題:How to work with cookies in ASP.NET Core, 作者:Joydip Kanjilal
【51CTO譯稿,合作站點轉(zhuǎn)載請注明原文譯者和出處為51CTO.com】