0

0

.NET Web API如何实现身份验证和授权_身份验证授权实现方案

煙雲

煙雲

发布时间:2025-11-19 18:49:31

|

676人浏览过

|

来源于php中文网

原创

答案:.NET Web API 中常用 JWT 实现身份验证,通过 AddJwtBearer 配置令牌验证参数,并在登录时生成带用户信息的 Token;启用 UseAuthentication 与 UseAuthorization 中间件后,可结合 [Authorize(Roles)] 或自定义策略实现基于角色或声明的授权;对于完整用户体系,推荐集成 ASP.NET Core Identity 管理用户和角色;此外,还可选用 OAuth 2.0、API Key 或 Basic Auth 方案,需根据场景选择并确保 HTTPS 加密与 Token 安全。

.net web api如何实现身份验证和授权_身份验证授权实现方案

在构建 .NET Web API 应用时,实现安全的身份验证和授权是保障系统数据安全的关键环节。合理的方案不仅能防止未授权访问,还能支持灵活的权限控制。以下是几种常见且实用的身份验证与授权实现方式。

使用 JWT Bearer Token 实现身份验证

JWT(JSON Web Token)是目前 Web API 中最常用的身份验证机制之一。用户登录后,服务器生成一个包含用户信息的加密 Token 并返回给客户端,后续请求通过 HTTP 头部中的 Authorization: Bearer 进行身份识别。

在 .NET 中启用 JWT 验证:

  • 安装 NuGet 包:Microsoft.AspNetCore.Authentication.JwtBearer
  • Program.cs 中配置认证服务:
builder.Services.AddAuthentication(options =>
{
options.DefaultAuthenticateScheme = JwtBearerDefaults.AuthenticationScheme;
options.DefaultChallengeScheme = JwtBearerDefaults.AuthenticationScheme;
})
.AddJwtBearer(options =>
{
options.TokenValidationParameters = new TokenValidationParameters
{
ValidateIssuer = true,
ValidateAudience = true,
ValidateLifetime = true,
ValidateIssuerSigningKey = true,
ValidIssuer = "your-issuer",
ValidAudience = "your-audience",
IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes("your-secret-key"))
};
});

// 启用认证中间件
app.UseAuthentication();
app.UseAuthorization();
  • 登录接口生成 Token 示例:
var token = new JwtSecurityToken(
issuer: "your-issuer",
audience: "your-audience",
claims: new[] { new Claim(ClaimTypes.Name, username) },
expires: DateTime.Now.AddMinutes(30),
signingCredentials: new SigningCredentials(new SymmetricSecurityKey(Encoding.UTF8.GetBytes("your-secret-key")), SecurityAlgorithms.HmacSha256)
);
return Ok(new { token = new JwtSecurityTokenHandler().WriteToken(token) });

基于角色或策略的授权控制

在完成身份验证后,通常需要进一步限制用户能访问的资源。.NET 提供了基于角色(Role-based)和策略(Policy-based)的授权机制。

360智图
360智图

AI驱动的图片版权查询平台

下载
  • 启用授权服务后,可在控制器或方法上添加 [Authorize] 特性
  • 按角色限制访问:
[Authorize(Roles = "Admin")]
[HttpGet("admin-data")]
public IActionResult GetAdminData()
{
return Ok("Only admins can see this.");
}
  • 定义自定义策略(如要求邮箱验证):
// 在 Program.cs 中添加策略
builder.Services.AddAuthorization(options =>
{
options.AddPolicy("EmailVerified", policy =>
policy.RequireClaim("email_verified", "true"));
}); // 使用策略
[Authorize(Policy = "EmailVerified")]
[HttpGet("verified-user")]
public IActionResult GetVerifiedData()

结合 Identity 实现用户管理

对于需要完整用户体系的应用,推荐使用 ASP.NET Core Identity。它内置了用户注册、登录、角色管理、密码哈希等功能,可与 Entity Framework 集成。

  • 添加 Identity 服务:
builder.Services.AddIdentity()
.AddEntityFrameworkStores();
  • 配合 Identity 登录后生成 JWT 或使用 Cookie 认证
  • 可通过 UserManager 和 SignInManager 管理用户生命周期

其他可选方案

  • OAuth 2.0 / OpenID Connect:适用于第三方登录(如 Google、GitHub),可使用 Microsoft.Identity.Web 集成 Azure AD 或外部提供者
  • API Key 验证:适合服务间调用,通过请求头校验固定密钥
  • Basic Authentication:简单但不推荐用于公网,需配合 HTTPS 使用

基本上就这些。选择哪种方案取决于应用场景:内部系统可用 API Key,多租户平台建议 JWT + Identity,集成企业登录则考虑 OAuth。关键是确保传输加密(HTTPS)、Token 安全存储与合理过期策略。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

176

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

212

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

406

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

531

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6414

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

339

2023.11.23

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.2万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号