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

溫馨提示×

溫馨提示×

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

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

AspNetCore WebApi怎么認證與授權

發布時間:2021-03-04 16:11:21 來源:億速云 閱讀:159 作者:TREX 欄目:開發技術

前言

本篇內容主要講解“AspNetCore WebApi怎么認證與授權”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“AspNetCore WebApi怎么認證與授權”吧!


什么是Token

Token是服務端生成的一串字符串,以作客戶端進行請求的一個令牌,當第一次登錄后,服務器生成一個Token便將此Token返回給客戶端,以后客戶端只需帶上這個Token前來請求數據即可,無需再次帶上用戶名和密碼。

什么是JWT

Json web token (JWT),是為了在網絡應用環境間傳遞聲明而執行的一種基于JSON的開放標準((RFC 7519).該token被設計為緊湊且安全的,特別適用于分布式站點的單點登錄(SSO)場景。JWT的聲明一般被用來在身份提供者和服務提供者間傳遞被認證的用戶身份信息,以便于從資源服務器獲取資源,也可以增加一些額外的其它業務邏輯所必須的聲明信息,該token也可直接被用于認證,也可被加密。

JWT認證流程

AspNetCore WebApi怎么認證與授權

從圖中可以看出主要有兩部分組成:1、獲取Token,2、通過Token進行授權。

使用JWT認證

首先,安裝JwtBearer包。

dotnet add package Microsoft.AspNetCore.Authentication.JwtBearer --version 3.1.0

接下來,定義一個配置類,我這里為了簡單直接用常量代替了,你也可以放在配置文件中。

public class TokenParameter
{  
 public const string Issuer = "深度碼農";//頒發者  
 public const string Audience = "深度碼農";//接收者  
 public const string Secret = "1234567812345678";//簽名秘鑰  
 public const int AccessExpiration = 30;//AccessToken過期時間(分鐘)
}

接下來,定義一個通過用戶名和密碼,獲取Token的控制器。

[Route("api/oauth")]
[ApiController]
public class OAuthController : ControllerBase
{
 /// <summary>
 /// 獲取Token
 /// </summary>
 /// <returns></returns>
 [HttpGet]
 [Route("token")]
 public ActionResult GetAccessToken(string username, string password)
 {
  //這兒在做用戶的帳號密碼校驗。我這兒略過了。
  if (username != "admin" || password != "admin")
   return BadRequest("Invalid Request");

  var claims = new[]
  {
   new Claim(ClaimTypes.Name, username),
   new Claim(ClaimTypes.Role, ""),
  };

  var key = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(TokenParameter.Secret));
  var credentials = new SigningCredentials(key, SecurityAlgorithms.HmacSha256);
  var jwtToken = new JwtSecurityToken(TokenParameter.Issuer, TokenParameter.Audience, claims, expires: DateTime.UtcNow.AddMinutes(TokenParameter.AccessExpiration), signingCredentials: credentials);
  var token = new JwtSecurityTokenHandler().WriteToken(jwtToken);

  return Ok(token);
 }
}

接下來,添加Token身份認證到容器(Startup.ConfigureServices)。

services.AddAuthentication(x =>
{
 x.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
 x.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
}).AddJwtBearer(x =>
{
 x.RequireHttpsMetadata = false;
 x.SaveToken = true;
 x.TokenValidationParameters = new TokenValidationParameters
 {     
  ValidateIssuerSigningKey = true,//是否調用對簽名securityToken的SecurityKey進行驗證
  IssuerSigningKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes(TokenParameter.Secret)),//簽名秘鑰
  ValidateIssuer = true,//是否驗證頒發者
  ValidIssuer = TokenParameter.Issuer, //頒發者
  ValidateAudience = true, //是否驗證接收者
  ValidAudience = TokenParameter.Audience,//接收者
  ValidateLifetime = true,//是否驗證失效時間
 };
});

接下來,添加身份認證到中間件(Startup.Configure)。

app.UseAuthentication();//必須在app.UseAuthorization();之前

接下來,控制器需要授權控制的添加[Authorize]。

[HttpGet("{id}")]
[Authorize]
public async Task<ActionResult<Todo>> GetTodo(Guid id)
{
 var todo = await context.Todo.FindAsync(id);

 if (todo == null)
 {
  return NotFound();
 }

 return todo;
}

最后,我們測試一下接口,效果如下。

AspNetCore WebApi怎么認證與授權

這時會返回401,因為身份認證沒有通過,說明身份驗證起效果了。

接下來我們訪問一下GetAccessToken接口,拿到Token,在訪問GetTodo接口時放入Token,我們可以看到訪問成功了。

AspNetCore WebApi怎么認證與授權

AspNetCore WebApi怎么認證與授權

小結

到此,相信大家對“AspNetCore WebApi怎么認證與授權”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

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

AI

溆浦县| 鹤岗市| 临朐县| 垫江县| 乐都县| 阳信县| 平罗县| 普陀区| 仙游县| 施秉县| 鄂托克前旗| 蓬安县| 盐池县| 定兴县| 宁河县| 东至县| 夏邑县| 宁阳县| 墨玉县| 晋城| 淅川县| 阜平县| 乡宁县| 琼海市| 冕宁县| 华蓥市| 仁怀市| 林州市| 阿尔山市| 西昌市| 吉木乃县| 阜新| 汝城县| 峨边| 山东省| 师宗县| 西青区| 上蔡县| 武胜县| 抚宁县| 兴隆县|