手把手教你AspNetCore WebApi認(rèn)證與授權(quán)的方法
前言
這幾天小明又有煩惱了,之前給小紅的接口沒有做認(rèn)證授權(quán),直接裸奔在線上,被馬老板發(fā)現(xiàn)后狠狠的罵了一頓,趕緊讓小明把授權(quán)加上。趕緊Baidu一下,發(fā)現(xiàn)大家都在用JWT認(rèn)證授權(quán),這個倒是挺適合自己的。
什么是Token
Token是服務(wù)端生成的一串字符串,以作客戶端進行請求的一個令牌,當(dāng)?shù)谝淮蔚卿浐螅?wù)器生成一個Token便將此Token返回給客戶端,以后客戶端只需帶上這個Token前來請求數(shù)據(jù)即可,無需再次帶上用戶名和密碼。
什么是JWT
Json web token (JWT),是為了在網(wǎng)絡(luò)應(yīng)用環(huán)境間傳遞聲明而執(zhí)行的一種基于JSON的開放標(biāo)準(zhǔn)((RFC 7519).該token被設(shè)計為緊湊且安全的,特別適用于分布式站點的單點登錄(SSO)場景。JWT的聲明一般被用來在身份提供者和服務(wù)提供者間傳遞被認(rèn)證的用戶身份信息,以便于從資源服務(wù)器獲取資源,也可以增加一些額外的其它業(yè)務(wù)邏輯所必須的聲明信息,該token也可直接被用于認(rèn)證,也可被加密。
JWT認(rèn)證流程

從圖中可以看出主要有兩部分組成:1、獲取Token,2、通過Token進行授權(quán)。
使用JWT認(rèn)證
首先,安裝JwtBearer包。
dotnet add package Microsoft.AspNetCore.Authentication.JwtBearer --version 3.1.0
接下來,定義一個配置類,我這里為了簡單直接用常量代替了,你也可以放在配置文件中。
public class TokenParameter
{
public const string Issuer = "深度碼農(nóng)";//頒發(fā)者
public const string Audience = "深度碼農(nóng)";//接收者
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身份認(rèn)證到容器(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,//是否調(diào)用對簽名securityToken的SecurityKey進行驗證
IssuerSigningKey = new SymmetricSecurityKey(Encoding.ASCII.GetBytes(TokenParameter.Secret)),//簽名秘鑰
ValidateIssuer = true,//是否驗證頒發(fā)者
ValidIssuer = TokenParameter.Issuer, //頒發(fā)者
ValidateAudience = true, //是否驗證接收者
ValidAudience = TokenParameter.Audience,//接收者
ValidateLifetime = true,//是否驗證失效時間
};
});
接下來,添加身份認(rèn)證到中間件(Startup.Configure)。
app.UseAuthentication();//必須在app.UseAuthorization();之前
接下來,控制器需要授權(quán)控制的添加[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;
}
最后,我們測試一下接口,效果如下。

這時會返回401,因為身份認(rèn)證沒有通過,說明身份驗證起效果了。
接下來我們訪問一下GetAccessToken接口,拿到Token,在訪問GetTodo接口時放入Token,我們可以看到訪問成功了。


小結(jié)
目前為止,小明把授權(quán)認(rèn)證搞定了,趕緊給馬老板匯報工作去吧。當(dāng)然這個授權(quán)認(rèn)證還是非常簡單的,還有很多等待的小伙伴們?nèi)グl(fā)掘,比如如何自動刷新Token?如何強制Token失效?OAuth其他實現(xiàn)方式等等?大家如果有興趣,讓小明下次告訴你們。
到此這篇關(guān)于手把手教你AspNetCore WebApi認(rèn)證與授權(quán)的方法的文章就介紹到這了,更多相關(guān)AspNetCore WebApi認(rèn)證與授權(quán)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
ASP.NET Core啟動地址配置方法及優(yōu)先級順序
這篇文章主要介紹了ASP.NET Core啟動地址配置方法及優(yōu)先級順序,如果在同一臺機器上運行多個ASP.NET Core實例,使用默認(rèn)值肯定不合適,下面我們一起進入文章了解具體內(nèi)容吧2022-03-03
Asp.net SignalR創(chuàng)建實時聊天應(yīng)用程序
這篇文章主要介紹了Asp.net SignalR創(chuàng)建實時聊天應(yīng)用程序,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-11-11
win10下vs2015配置Opencv3.1.0詳細(xì)過程
這篇文章主要為大家詳細(xì)介紹了win10下vs2015配置Opencv3.1.0的詳細(xì)過程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11
asp.net javascript 文件無刷新上傳實例代碼
最近在寫C# .net代碼的時候,遇到一個上傳刷新的問題。2009-06-06
在ASP.NET?Core微服務(wù)架構(gòu)下使用RabbitMQ實現(xiàn)CQRS模式的方法
ASP.NET Core微服務(wù)架構(gòu)中,使用RabbitMQ作為消息隊列服務(wù),通過實現(xiàn)CQRS模式,將寫操作和讀操作分離,以提高系統(tǒng)的性能和可伸縮性,本文小編將為大家介紹如何在ASP.NET Core微服務(wù)架構(gòu)下使用RabbitMQ來實現(xiàn)CQRS模式,感興趣的朋友一起看看吧2024-01-01

