欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Asp.Net Core中基于Session的身份驗(yàn)證的實(shí)現(xiàn)

 更新時(shí)間:2018年09月18日 10:14:43   作者:Net_win  
這篇文章主要介紹了Asp.Net Core中基于Session的身份驗(yàn)證的實(shí)現(xiàn)

在Asp.Net框架中提供了幾種身份驗(yàn)證方式:Windows身份驗(yàn)證、Forms身份驗(yàn)證、passport身份驗(yàn)證(單點(diǎn)登錄驗(yàn)證)。

每種驗(yàn)證方式都有適合它的場景:

1.Windowss身份驗(yàn)證通常用于企業(yè)內(nèi)部環(huán)境,Windows Active Directory就是基于windows平臺的身份驗(yàn)證實(shí)現(xiàn);
2.Forms身份驗(yàn)證是Asp.Net框架中提出的另一種驗(yàn)證方式;
3.passport身份驗(yàn)證是微軟提供的基于自己的lives賬號實(shí)現(xiàn)的單點(diǎn)認(rèn)證服務(wù)。

Asp.net Core驗(yàn)證碼登錄遇到兩個(gè)小問題

第一是在Asp.net Core中引用dll,以往我們引用DLL都是直接引用,在Core里這樣是不行的,必須基于NuGet添加,或者基于project.json添加,然后保存VS會啟動還原類庫。

第二就是使用Session的問題,Core里使用Session需要添加Session類庫。

第一步:在你的項(xiàng)目上基于NuGet添加:

install-package Microsoft.AspNetCore.Session -ver 2.0

install-package Microsoft.AspNetCore.Http.Extensions -ver 2.0

第二步:修改startup.cs

在startup.cs找到方法ConfigureServices(IServiceCollection services) 注入Session(這個(gè)地方是Asp.net Core pipeline):

services.AddSession();

接下來我們要告訴Asp.net Core使用內(nèi)存存儲Session數(shù)據(jù),在Configure(IApplicationBuilder app,...)方法中添加代碼:

app.UseSession();

基于Session的身份驗(yàn)證實(shí)現(xiàn)

這種方式可能是在Asp.Net框架提供的幾種驗(yàn)證方式之外的最常用的身份驗(yàn)證方式。

實(shí)現(xiàn)原理

1.客戶端發(fā)送身份認(rèn)證數(shù)據(jù)到服務(wù)器端
2.服務(wù)器收到并驗(yàn)證后將用戶信息保存到Session對象中,然后生成對應(yīng)的標(biāo)識并將標(biāo)識寫入cookie中
3.當(dāng)客戶端下次請求時(shí)帶上該cookie標(biāo)識
4.服務(wù)器通過該cookie標(biāo)識從session對象中獲取對應(yīng)的用戶信息

Asp.Net Core中的Session身份認(rèn)證實(shí)現(xiàn)

​ 基于Session的身份認(rèn)證并不是Asp.Net Core中推薦的認(rèn)證方式,因?yàn)锳sp.Net Core中有更高級的Forms身份認(rèn)證方式,不過在這里不是本文章的主題,我們只講如何在Asp.Net Core中實(shí)現(xiàn)基于Session的身份認(rèn)證。

我們先創(chuàng)建一個(gè)用于代碼演示的基礎(chǔ)項(xiàng)目

dotnet new razor -n SessionSample

在startup.cs中啟用session功能

public class Startup
{
  public void ConfigureServices(IServiceCollection services)
  {
    ...
    //添加session服務(wù)
    services.AddSession();
  }
  public void Configure(IApplicationBuilder app, IHostingEnvironment env)
  {
    ...
    //啟用session
    app.UseSession();
    app.UseMvc();
  }
}

創(chuàng)建一個(gè)MyPage.cs文件,我們在該類中實(shí)現(xiàn)了一個(gè)IsLogin屬性,該屬性用來判斷用戶的登陸狀態(tài):

public class MyPage:PageModel
{
  protected bool IsLogin
  {
    get
    {
      string userId = null;
      //從sessin中獲取UserId對應(yīng)的用戶信息來判斷用戶是否登陸
      if (HttpContext.Session.TryGetValue("UserId", out byte[] bytes))
      {
        userId = Encoding.UTF8.GetString(bytes);
      }
      return !string.IsNullOrWhiteSpace(userId);
    }
  }
}

我們已經(jīng)實(shí)現(xiàn)了驗(yàn)證,現(xiàn)在缺少的是如何在session中添加UserId的信息,我們來創(chuàng)建一個(gè)Login頁面:

dotnet new page -n Login
public class LoginModel : MyPage
{
  public void OnGet()
  {
    if(IsLogin)
    {
      //如果已經(jīng)登陸就跳轉(zhuǎn)到/Index頁面
      RedirectToPage("/Index");
    }
  }
  public IActionResult OnPost()
  {
    //這里我們將UserId寫入session中
    HttpContext.Session.SetString("UserId", Guid.NewGuid().ToString());
    return RedirectToPage("/Index");
  }
}

給現(xiàn)有的頁面添加驗(yàn)證功能,打開Index頁面,添加如下代碼:

public class IndexModel : MyPage
{
  public IActionResult OnGet()
  {
    if (!IsLogin)
    {
      return RedirectToPage("/Login");
    }
    return Page();
  }
}

OK!我們已經(jīng)實(shí)現(xiàn)了身份認(rèn)證。

源代碼

總結(jié)

​ 我們描述了傳統(tǒng)Asp.Net中提供的幾種身份認(rèn)證方式,并在Asp.Net Core實(shí)現(xiàn)了一種雖然不標(biāo)準(zhǔn)但是常用的身份認(rèn)證機(jī),看起了與Asp.Net中的用法并沒有什么區(qū)別。

​ 在Asp.Net Core中這種用法似乎并不受歡迎,可能是因?yàn)锳sp.Net Core提供了更高級的身份驗(yàn)證機(jī)制吧,那么這篇文章存在的意義呢?權(quán)當(dāng)做是對Asp.Net的一種紀(jì)念吧!

現(xiàn)在是.net core的時(shí)代,讓.net洗洗睡吧!以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論