一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - .NET core 3.0如何使用Jwt保護api詳解

.NET core 3.0如何使用Jwt保護api詳解

2020-06-22 15:15成天 ASP.NET教程

這篇文章主要給大家介紹了關于.NET core 3.0如何使用Jwt保護api的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用.NET core 3.0具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

摘要:

本文演示如何向有效用戶提供jwt,以及如何在webapi中使用該token通過JwtBearerMiddleware中間件對用戶進行身份認證。

認證和授權區別?

首先我們要弄清楚認證(Authentication)和授權(Authorization)的區別,以免混淆了。認證是確認的過程中你是誰,而授權圍繞是你被允許做什么,即權限。顯然,在確認允許用戶做什么之前,你需要知道他們是誰,因此,在需要授權時,還必須以某種方式對用戶進行身份驗證。

什么是JWT?

根據維基百科的定義,JSON WEB Token(JWT),是一種基于JSON的、用于在網絡上聲明某種主張的令牌(token)。JWT通常由三部分組成:頭信息(header),消息體(payload)和簽名(signature)。

頭信息指定了該JWT使用的簽名算法:

?
1
header = '{"alg":"HS256","typ":"JWT"}'

HS256表示使用了HMAC-SHA256來生成簽名。

消息體包含了JWT的意圖:

?
1
payload = '{"loggedInAs":"admin","iat":1422779638}'//iat表示令牌生成的時間

未簽名的令牌由base64url編碼的頭信息和消息體拼接而成(使用"."分隔),簽名則通過私有的key計算而成:

?
1
2
3
key = 'secretkey'
unsignedToken = encodeBase64(header) + '.' + encodeBase64(payload)
signature = HMAC-SHA256(key, unsignedToken)

最后在未簽名的令牌尾部拼接上base64url編碼的簽名(同樣使用"."分隔)就是JWT了:

?
1
2
3
token = encodeBase64(header) + '.' + encodeBase64(payload) + '.' + encodeBase64(signature)
 
# token看起來像這樣: eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJsb2dnZWRJbkFzIjoiYWRtaW4iLCJpYXQiOjE0MjI3Nzk2Mzh9.gzSraSYS8EXBxLN_oWnFSRgCzcmJmMjLiuyu5CSpyHI

JWT常常被用作保護服務端的資源(resource),客戶端通常將JWT通過HTTP的Authorization header發送給服務端,服務端使用自己保存的key計算、驗證簽名以判斷該JWT是否可信:

?
1
Authorization: Bearer eyJhbGci*...<snip>...*yu5CSpyHI

準備工作

使用vs2019創建webapi項目,并且安裝nuget包

?
1
Microsoft.AspNetCore.Authentication.JwtBearer

.NET core 3.0如何使用Jwt保護api詳解

Startup類

ConfigureServices 添加認證服務

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
services.AddAuthentication(options =>
   {
    options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
    options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
    options.DefaultScheme = JwtBearerDefaults.AuthenticationScheme;
   }).AddJwtBearer(options =>
   {
    options.SaveToken = true;
    options.RequireHttpsMetadata = false;
    options.TokenValidationParameters = new TokenValidationParameters()
    {
     ValidateIssuer = true,
     ValidateAudience = true,
     ValidAudience = "https://www.cnblogs.com/chengtian",
     ValidIssuer = "https://www.cnblogs.com/chengtian",
     IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("SecureKeySecureKeySecureKeySecureKeySecureKeySecureKey"))
    };
   });

Configure 配置認證中間件

?
1
app.UseAuthentication();//認證中間件、

創建一個token

添加一個登錄model命名為LoginInput

?
1
2
3
4
5
6
7
public class LoginInput
 {
 
  public string Username { get; set; }
 
  public string Password { get; set; }
 }

添加一個認證控制器命名為AuthenticateController

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
[Route("api/[controller]")]
 public class AuthenticateController : Controller
 {
  [HttpPost]
  [Route("login")]
  public IActionResult Login([FromBody]LoginInput input)
  {
   //從數據庫驗證用戶名,密碼
   //驗證通過 否則 返回Unauthorized
 
   //創建claim
   var authClaims = new[] {
    new Claim(JwtRegisteredClaimNames.Sub,input.Username),
    new Claim(JwtRegisteredClaimNames.Jti,Guid.NewGuid().ToString())
   };
   IdentityModelEventSource.ShowPII = true;
   //簽名秘鑰 可以放到json文件中
   var authSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("SecureKeySecureKeySecureKeySecureKeySecureKeySecureKey"));
 
   var token = new JwtSecurityToken(
     issuer: "https://www.cnblogs.com/chengtian",
     audience: "https://www.cnblogs.com/chengtian",
     expires: DateTime.Now.AddHours(2),
     claims: authClaims,
     signingCredentials: new SigningCredentials(authSigningKey, SecurityAlgorithms.HmacSha256)
     );
 
   //返回token和過期時間
   return Ok(new
   {
    token = new JwtSecurityTokenHandler().WriteToken(token),
    expiration = token.ValidTo
   });
  }
 }

添加api資源

利用默認的控制器WeatherForecastController

  • 添加個Authorize標簽
  • 路由調整為:[Route("api/[controller]")] 代碼如下
?
1
2
3
4
[Authorize]
[ApiController]
[Route("api/[controller]")]
public class WeatherForecastController : ControllerBase

到此所有的代碼都已經準好了,下面進行運行測試

運行項目

使用postman進行模擬

輸入url:https://localhost:44364/api/weatherforecast

.NET core 3.0如何使用Jwt保護api詳解

發現返回時401未認證,下面獲取token

通過用戶和密碼獲取token

.NET core 3.0如何使用Jwt保護api詳解

如果我們的憑證正確,將會返回一個token和過期日期,然后利用該令牌進行訪問

利用token進行請求

.NET core 3.0如何使用Jwt保護api詳解

ok,最后發現請求狀態200!

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對服務器之家的支持。

原文鏈接:https://www.cnblogs.com/chengtian/p/11927663.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产香蕉在线视频 | 日本三级免费观看 | 亚洲AV人无码综合在线观看蜜桃 | 国产免费丝袜调教视频 | 日本在线www | brazzersvideo欧美最新 | 日本高清免费中文字幕不卡 | 成人免费网站视频ww | 桃花岛在线| 国产自产在线 | 2021久久| 色婷婷影院在线视频免费播放 | 久久久这里有精品999 | 激情三级做爰在线观看激情 | 秋霞黄色 | 99在线在线视频免费视频观看 | 手机看片国产免费久久网 | 日韩一区三区 | a看片 | 亚洲 欧美 国产 在线 日韩 | 日本人在线看片 | 国内精品久久久久影院男同志 | 日韩欧美一区二区三区免费看 | 黑人巨荃大战乌克兰美女 | 操人网 | 亚洲热在线视频 | 91久久99热青草国产 | 亚洲成年网 | 把老师操了 | aⅴ视频在线免播放观看 | 国产成人在线免费观看 | 人人艹在线视频 | 消息称老熟妇乱视频一区二区 | 福利一区在线观看 | 九九久久国产精品大片 | 免费一区二区视频 | 8x8x丝袜美女| 午夜影院在线免费观看 | 国产成人精选免费视频 | 91制片厂制作传媒破解版免费 | 国产精品第页 |