Easy-DotNET Easy-DotNET
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
🏠首页
  • 知识地图
  • 源码脑图

    • 总览
    • Program
    • WebApplication
    • Host主机
    • WebHost主机
    • 依赖注入
    • Autofac
    • Middleware中间件
    • RateLimiter限制速率
    • 响应缓存、请求解压缩
  • 设计初衷
  • 克隆
  • 类型转换
  • 日期时间
  • IO流
  • 工具类
  • 语言特性
  • 集合类
  • Codec编码
  • 文本操作
  • 数学
  • 图片
  • 网络
  • Emoji表情
  • C# 12
  • C# 11
  • C# 10
  • C# 9.0
  • C# 8.0
  • C# 早期版本
  • C# 教程
  • ORM
  • 定时任务
  • 日志
  • 认证与授权
  • Swagger
  • 对象映射
  • 熔断重试限流
  • 缓存
  • 注册发现
  • 网关
  • GraphQL
  • 更多
  • Docker

    • 简介
    • Adminer
    • Apisix
    • Apollo
    • Cassandra
    • Cerebro
    • ClickHouse
    • Consul
    • EasyMock
    • Elasticsearch
    • Emqx
    • FastDFS
    • Flink
    • Gitlab
    • Jenkins
    • Jrebel
    • MariaDB
    • MySQL
    • Percona
    • Phpmyadmin
    • PostgreSQL
    • Redis
  • Linux

    • 查看Linux系统信息
    • CentOS7调整磁盘分区
    • IO压测
    • 图形化监控工具Cockpit
  • 总览
  • 列表

    • 算法数据结构
    • API
    • 应用框架
    • 应用模板
    • 操作系统
    • 工作流
    • 入门套件
    • 示例
    • 人工智能
    • 程序集
    • Assets
    • 认证授权
    • Blazor
    • 区块链
    • 书籍
    • 自动构建
    • 报表
    • 缓存
    • 日历
    • 聊天
    • CLI
    • CLR
    • CMS
    • 代码分析和指标
    • 代码片段
    • 压缩
    • 持续集成
    • 密码学
    • 数据库
    • 数据库驱动
    • 日期时间
    • 反编译
    • 部署
    • DirectX
    • 分布式计算
    • DLR
    • 文档
    • 电商支付
    • 模拟器
    • 环境管理
    • ETL
    • 事件消息
    • Exception
    • 扩展
    • 函数式编程
    • 游戏引擎
    • GIS
    • Git工具
    • 绘图
    • GraphQL
    • GUI
    • HTML-CSS
    • HTTP
    • IDE
    • 图片处理
    • 安装工具
    • 交互式编程
    • 国际化
    • 互操作性
    • IoC
    • JS引擎
    • 日志
    • 机器学习和数据科学
    • Markdown
    • 邮件
    • 数学
    • 媒体
    • 指标
    • 微型框架
    • 最小化器
    • MVVM
    • 网络
    • 对象映射
    • Office
    • OpenAI
    • ORM
    • 包管理器
    • PDF
    • 性能分析工具
    • 协议
    • 推送通知
    • SQL构建器
    • 消息队列
    • RPC
    • 响应式编程
    • 实时通信
    • 正则表达式
    • 任务调度
    • SDK和API
    • 搜索引擎
    • 序列化
    • SMS
    • 状态机
    • 静态站点生成
    • 强命名
    • 风格指南
    • 模板引擎
    • 测试
    • 工具
    • 交易
    • UI自动测试
    • Visual Studio 插件
    • Web浏览器
    • Web框架
    • WebServers
    • WebSocket
    • Windows服务
    • WPF
    • 解析器
    • 源码生成
    • 其他
    • 资源
  • AspNetCore面试题
  • Elasticsearch面试题
  • MongoDB面试题
  • MySql面试题
  • Nginx面试题
  • RabbitMQ面试题
  • Redis面试题
  • 设计模式
  • 微服务
🧑‍💻.NET Blog
GitHub (opens new window)
npm
  • 简介
  • ORM

    • EFCore
    • Dapper
    • FreeSql
    • SqlSugar
  • 任务调度

    • Hangfire
    • Quartz
    • FluentScheduler
    • Coravel
    • Quartzmin
  • 日志

    • Serilog
    • NLog
    • Log4Net
    • Stackdriver
    • ExceptionLess
  • 身份认证与授权

    • IdentityServer4
    • Identity
      • 什么是Identity?
      • Identity的工作原理
      • Identity的主要组件
      • 在ASP.NET Core中使用Identity
        • 注册Identity服务
        • 配置Identity服务的选项
        • 添加Identity的中间件
        • 使用Identity的API
        • 登录用户
        • 注销用户
        • 检查用户是否已登录
        • 授权用户访问资源
        • 总结
    • JWTBearer
    • Auth0
    • OpenIddict
  • Swagger文档

    • Swagger
    • Swashbuckle
    • NSwag
    • ReDoc
  • 对象映射

    • AutoMapper
    • EmitMapper
    • AgileMapper
    • Mapster
  • 消息传递

    • MediatR
    • MassTransit
    • Rebus
    • NServiceBus
  • 熔断重试限流

    • Polly
    • Resilience4j
    • AkkaNET
  • 缓存

    • CsRedis
    • FreeRedis
    • EasyCaching
    • StackExchangeRedis
    • CacheCow
    • NCache
    • Memory
  • 注册发现

    • Consul
    • Nacos
    • Apollo
  • 网关

    • Ocelot
    • Kong
    • Traefik
    • Zuul
  • GraphQL

    • GraphQLPlatform
    • GraphQLdotnet
  • 更多

    • NodaTime
    • FluentAssertions
    • Humanizer
    • 爬虫-AngleSharp
    • 邮件-MailKit
  • NET微服务
  • 身份认证与授权
一个大西瓜
2023-04-20
目录

Identity

开源地址

Github:https://github.com/dotnet/aspnetcore/tree/main/src/Identity (opens new window)

在ASP.NET Core中,身份验证和授权是构建Web应用程序的核心组件之一。.NET身份验证和授权框架Identity提供了一种简单的方法来实现身份验证和授权,从而保护应用程序的资源并限制对资源的访问。本文将介绍Identity的基本概念、实现方式以及如何在ASP.NET Core中使用它。

# 什么是Identity?

.NET身份验证和授权框架Identity是一个用于管理用户身份验证和授权的框架。它可以轻松地添加到任何.NET Core应用程序中,以便处理用户身份验证、注册、登录、密码重置等基本任务。使用Identity,您可以为Web应用程序构建自定义身份验证和授权系统。

在ASP.NET Core中,Identity是以NuGet包的形式提供的,所以您需要通过NuGet包管理器将其添加到您的项目中。Identity包包含了一组工具和中间件,用于管理用户身份验证和授权的所有方面。

# Identity的工作原理

.NET身份验证和授权框架Identity是一个非常灵活的框架,它允许您自定义身份验证和授权策略。Identity使用一些默认值来简化Web应用程序的身份验证和授权流程,但您可以轻松地覆盖这些默认值以满足您的需求。

Identity的工作原理是,当用户登录Web应用程序时,Identity会创建一个持久化的安全上下文(Security Context),并将其存储在Cookie中。在用户访问Web应用程序的每个页面时,Identity都会检查这个安全上下文以验证用户的身份,并根据需要授权用户访问受保护的资源。

# Identity的主要组件

.NET身份验证和授权框架Identity包括以下组件:

  • IdentityUser :表示Web应用程序中的用户。IdentityUser类包含用户的基本属性,例如用户名、电子邮件地址、密码等。
  • IdentityRole :表示Web应用程序中的角色。角色是一组权限的集合,用于授权用户访问受保护的资源。
  • IdentityDbContext :Identity的核心组件之一,用于管理用户和角色的数据存储。它可以与任何关系数据库(如SQL Server、MySQL、PostgreSQL等)一起使用。
  • UserManager :用于管理用户的API。UserManager类提供了一组用于创建、更新、删除用户的API。
  • RoleManager :用于管理角色的API。RoleManager类提供了一组用于创建、更新、删除角色的API。
  • SignInManager :用于管理用户身份验证和登出的API。SignInManager类提供了一组用于验证用户身份、创建用户Cookie并注销用户的API。
  • AuthenticationMiddleware :用于验证用户身份的ASP.NET Core中间件。它通过验证Cookie中的安全上下文来验证用户身份。
  • AuthorizationMiddleware :用于授权用户访问受保护资源的ASP.NET Core中间件。它检查用户的安全上下文,以确保用户具有足够的权限访问受保护的资源。

# 在ASP.NET Core中使用Identity

在ASP.NET Core中使用Identity非常简单。您只需要按照以下步骤即可开始:

  1. 将Microsoft.AspNetCore.Identity NuGet包添加到您的项目中。
  2. 在Startup.cs文件中注册Identity服务。
  3. 配置Identity服务的选项(可选)。
  4. 添加Identity的中间件到应用程序管道中。
  5. 使用Identity的API来管理用户、角色和授权。

# 注册Identity服务

要在ASP.NET Core中使用Identity,您需要在Startup.cs文件中注册Identity服务。在ConfigureServices方法中,添加以下代码:


services.AddIdentity<IdentityUser, IdentityRole>()
        .AddEntityFrameworkStores<YourDbContext>()
        .AddDefaultTokenProviders();

上面的代码向服务集合中添加了Identity服务,并指定了IdentityUser和IdentityRole作为用户和角色的类型。然后,它使用Entity Framework作为Identity数据存储,并添加了默认的令牌提供程序。

# 配置Identity服务的选项

在注册Identity服务后,您可以配置Identity服务的选项。Identity服务有许多选项可供您配置,例如密码策略、用户锁定策略、Cookie设置等。您可以通过以下方式配置选项:


services.Configure<IdentityOptions>(options =>
{
    // 配置密码策略
    options.Password.RequireDigit = true;
    options.Password.RequireLowercase = true;
    options.Password.RequireUppercase = true;
    options.Password.RequireNonAlphanumeric = false;
    options.Password.RequiredLength = 8;

    // 配置用户锁定策略
    options.Lockout.DefaultLockoutTimeSpan = TimeSpan.FromMinutes(30);
    options.Lockout.MaxFailedAccessAttempts = 5;

    // 配置Cookie设置
    options.Cookies.ApplicationCookie.ExpireTimeSpan = TimeSpan.FromDays(30);
    options.Cookies.ApplicationCookie.LoginPath = "/Account/Login";
});

上面的代码配置了密码策略、用户锁定策略和Cookie设置。您可以根据需要自定义这些设置。

# 添加Identity的中间件

要使用Identity,您需要将AuthenticationMiddleware和AuthorizationMiddleware添加到应用程序管道中。在Configure方法中,添加以下代码:


app.UseAuthentication();
app.UseAuthorization();

上面的代码将AuthenticationMiddleware和AuthorizationMiddleware添加到应用程序管道中。这些中间件将在处理请求时验证用户身份和授权。

# 使用Identity的API

在将Identity添加到应用程序中后,您可以使用Identity的API来管理用户、角色和授权。下面是一些常见的Identity API的示例:

要注册用户,您可以使用UserManager.CreateAsync方法。以下是示例代码:


var user = new IdentityUser
{
    UserName = "username",
    Email = "user@example.com"
};

var result = await _userManager.CreateAsync(user, "password");
if (result.Succeeded)
{
    // 用户创建成功
}
else
{
    // 用户创建失败
}

上面的代码创建了一个新的IdentityUser对象,并使用UserManager.CreateAsync方法将其添加到数据库中。

# 登录用户

要登录用户,您可以使用SignInManager.PasswordSignInAsync方法。以下是示例代码:


var result = await _signInManager.PasswordSignInAsync("username", "password", true, false);
if (result.Succeeded)
{
    // 登录成功
}
else
{
    // 登录失败
}

上面的代码使用SignInManager.PasswordSignInAsync方法验证用户的用户名和密码,并创建一个身份验证Cookie。

# 注销用户

要注销用户,您可以使用SignInManager.SignOutAsync方法。以下是示例代码:


await _signInManager.SignOutAsync();

上面的代码使用SignInManager.SignOutAsync方法删除用户的身份验证Cookie并注销用户。

# 检查用户是否已登录

要检查用户是否已登录,您可以使用SignInManager.IsSignedIn方法。以下是示例代码:


if (_signInManager.IsSignedIn(User))
{
    // 用户已登录
}
else
{
    // 用户未登录
}

上面的代码使用SignInManager.IsSignedIn方法检查当前请求中的用户是否已登录。

# 授权用户访问资源

要授权用户访问资源,您可以使用AuthorizeAttribute。以下是示例代码:


[Authorize(Roles = "admin")]
public IActionResult AdminDashboard()
{
    // 只有管理员可以访问此资源
    return View();
}

上面的代码使用AuthorizeAttribute将AdminDashboard操作限制为具有“admin”角色的用户。

# 总结

.NET身份验证和授权框架Identity是一个功能强大的框架,可用于管理用户身份验证和授权。使用Identity,您可以轻松地添加身份验证和授权功能到ASP.NET Core应用程序中,并自定义身份验证和授权策略。在本文中,我们介绍了Identity的基本概念、实现方式以及如何在ASP.NET Core中使用它。我们还提供了一些常见的Identity API示例,希望这些示例可以帮助您开始使用Identity。

上次更新: 2023/04/26, 22:10:06
IdentityServer4
JWTBearer

← IdentityServer4 JWTBearer→

Theme by Vdoing | Copyright © 2019-2024 一个大西瓜 | MIT License | 苏ICP备2023013501号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式