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
    • JWTBearer
    • Auth0
    • OpenIddict
      • 安装
      • 身份验证
        • 配置OpenIddict
        • 创建JWT
        • 验证JWT
      • 授权
        • 配置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
目录

OpenIddict

开源地址

Github:https://github.com/openiddict/openiddict-core (opens new window)

OpenIddict是一个开源的身份验证和授权框架,可用于.NET应用程序。它支持多种身份验证和授权协议,如OAuth2,OpenID Connect和JWT等。OpenIddict使开发人员可以轻松地为他们的应用程序添加身份验证和授权功能,同时还提供了可扩展性和自定义选项。

# 安装

要使用OpenIddict,您需要在.NET应用程序中安装NuGet包。可以使用Visual Studio的NuGet包管理器或通过命令行运行以下命令:


dotnet add package OpenIddict

# 身份验证

在OpenIddict中,身份验证是通过创建和验证JWT(JSON Web Tokens)来完成的。JWT是一种安全的、基于标准的方法,用于在不同的应用程序和系统之间传递信息。JWT可以包含有关用户身份和权限的信息,并使用数字签名保证其真实性和完整性。

# 配置OpenIddict

要开始使用OpenIddict进行身份验证,您需要首先配置OpenIddict选项。您可以在应用程序的启动类中添加以下代码:


services.AddOpenIddict()
    .AddCore(options =>
    {
        options.UseEntityFrameworkCore()
            .UseDbContext<ApplicationDbContext>();
    })
    .AddServer(options =>
    {
        options.AllowAuthorizationCodeFlow()
            .RequireClientSecret(false)
            .UseAspNetCore()
            .EnableTokenEndpoint("/connect/token")
            .EnableAuthorizationEndpoint("/connect/authorize")
            .EnableLogoutEndpoint("/connect/logout")
            .AllowRefreshTokenFlow()
            .AllowPasswordFlow();
    });

上述代码中,我们使用AddOpenIddict方法将OpenIddict服务添加到应用程序中。接下来,我们使用AddCore方法配置OpenIddict的核心选项,包括使用Entity Framework Core和DbContext。然后,我们使用AddServer方法配置OpenIddict的服务器选项,包括允许授权代码流、禁用客户端秘钥、启用令牌、授权和注销端点,以及允许刷新令牌和密码流。

# 创建JWT

创建JWT需要使用OpenIddict提供的JwtManager类。您可以使用以下代码创建JWT:


var token = await _jwtManager.CreateTokenAsync(user, new Claim[]
{
    new Claim(JwtRegisteredClaimNames.Sub, user.Id),
    new Claim(JwtRegisteredClaimNames.Jti, Guid.NewGuid().ToString()),
    new Claim(JwtRegisteredClaimNames.Iat, DateTimeOffset.UtcNow.ToUnixTimeSeconds().ToString(),
        ClaimValueTypes.Integer64)
});

上述代码中,我们使用CreateTokenAsync方法创建JWT。该方法需要传递用户对象和要包含在JWT中的声明列表。在此示例中,我们添加了Sub、Jti和Iat声明。

# 验证JWT

验证JWT需要使用OpenIddict提供的TokenValidationParameters类。您可以使用以下代码验证JWT:


var tokenValidationParameters = new TokenValidationParameters
{
    ValidIssuer = _configuration["Jwt:Issuer"],
    ValidAudience = _configuration["Jwt:Audience"],
    IssuerSigningKey = new SymmetricSecurityKey(Encoding.UTF8.GetBytes(_configuration["Jwt:Key"])),
    ClockSkew = TimeSpan.Zero
};

var claimsPrincipal = _jwtManager.ValidateToken(token, tokenValidationParameters);

上述代码中,我们首先创建一个TokenValidationParameters对象,并指定JWT的签发者、受众和签名密钥。然后,我们使用ValidateToken方法验证JWT,并将其转换为ClaimsPrincipal对象。

# 授权

在OpenIddict中,授权是通过授权代码流或密码流完成的。授权代码流是指用户向应用程序授权访问某些资源,并在授权后返回一个授权代码,该代码可以交换为访问令牌。密码流是指用户向应用程序提供用户名和密码,并直接返回访问令牌。

# 配置OpenIddict

要开始使用OpenIddict进行授权,您需要首先配置OpenIddict选项。您可以在应用程序的启动类中添加以下代码:

services.AddOpenIddict()
    .AddCore(options =>
    {
        options.UseEntityFrameworkCore()
            .UseDbContext<ApplicationDbContext>();
    })
    .AddServer(options =>
    {
        options.AllowAuthorizationCodeFlow()
            .RequireClientSecret(false)
            .UseAspNetCore()
            .EnableTokenEndpoint("/connect/token")
            .EnableAuthorizationEndpoint("/connect/authorize")
            .EnableLogoutEndpoint("/connect/logout")
            .AllowRefreshTokenFlow()
            .AllowPasswordFlow();
    })
    .AddValidation(options =>
    {
        options.UseAspNetCore();
    });

上述代码中,我们添加了AddValidation方法来配置OpenIddict的验证选项。我们使用UseAspNetCore方法指定使用AspNetCore身份验证中间件来验证访问令牌。

# 授权代码流

授权代码流是通过授权码交换访问令牌来完成的。在OpenIddict中,我们可以使用AuthorizeAsync和ExchangeAsync方法来完成授权代码流。您可以使用以下代码:


// 生成授权URL
var authorizeRequest = new AuthorizeRequest
{
    ClientId = "client_id",
    RedirectUri = "https://example.com/callback",
    Scope = "openid profile email",
    ResponseType = "code",
    State = "state",
    Nonce = "nonce"
};

var authorizeUrl = await _interactionService.GenerateAuthorizationUriAsync(authorizeRequest);

// 处理授权回调
var authorizationContext = await _interactionService.GetAuthorizationContextAsync(returnUrl);

var authorizeResult = await _interactionService.HandleAuthorizationRequestAsync(authorizationContext, new AuthorizeRequest
{
    Code = "authorization_code",
    RedirectUri = "https://example.com/callback"
});

// 交换授权码获取访问令牌
var tokenResponse = await _tokenClient.RequestAuthorizationCodeTokenAsync(new AuthorizationCodeTokenRequest
{
    Address = disco.TokenEndpoint,
    ClientId = "client_id",
    ClientSecret = "client_secret",
    Code = authorizeResult.Code,
    RedirectUri = "https://example.com/callback"
});

上述代码中,我们首先使用GenerateAuthorizationUriAsync方法生成授权URL,然后在回调URL中使用HandleAuthorizationRequestAsync方法处理授权回调,最后使用RequestAuthorizationCodeTokenAsync方法交换授权码并获取访问令牌。

# 密码流

密码流是通过直接使用用户名和密码来获取访问令牌的。在OpenIddict中,我们可以使用TokenClient类来完成密码流。您可以使用以下代码:


var tokenResponse = await _tokenClient.RequestPasswordTokenAsync(new PasswordTokenRequest
{
    Address = disco.TokenEndpoint,
    ClientId = "client_id",
    ClientSecret = "client_secret",
    UserName = "username",
    Password = "password",
    Scope = "openid profile email"
});

上述代码中,我们使用RequestPasswordTokenAsync方法直接获取访问令牌。

# 结论

OpenIddict是一个强大的身份验证和授权框架,可用于.NET应用程序。它支持多种身份验证和授权协议,如OAuth2、OpenID Connect和JWT等。OpenIddict使开发人员可以轻松地为他们的应用程序添加身份验证和授权功能,并提供可扩展性和自定义选项。如果您正在开发.NET应用程序,并需要身份验证和授权功能,那么OpenIddict是一个非常不错的选择。

上次更新: 2023/04/26, 22:10:06
Auth0
Swagger

← Auth0 Swagger→

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