0

0

C# OpenID Connect实现方法 C#如何集成IdentityServer进行身份认证

星降

星降

发布时间:2026-02-12 12:47:12

|

679人浏览过

|

来源于php中文网

原创

identityserver6是.net 6+推荐的官方身份认证服务,替代已废弃的identityserver4;需显式配置client的allowedgranttypes、redirecturis等,客户端推荐使用microsoft.identity.web实现oidc认证。

c# openid connect实现方法 c#如何集成identityserver进行身份认证

IdentityServer 6 是当前主流选择,.NET 6+ 应优先用它替代已废弃的 IdentityServer4

IdentityServer4 自 2022 年底已停止维护,IdentityServer6 是官方推荐的继任者,基于 ASP.NET Core 6+ 原生构建,不再依赖 OWIN。如果你项目还在用 IdentityServer4,升级不是可选项——是安全必需项。

关键区别在于:

  • IdentityServer6 使用 AddIdentityServer() + UseIdentityServer() 注册中间件,配置全在 Program.cs 中完成
  • 不再需要 IdentityServerOptions 的复杂嵌套配置,而是通过 ConfigureServices 中的强类型 builder(如 services.AddIdentityServer().AddInMemoryClients(...))分层设置
  • 默认启用 PKCE,且强制要求 redirect_uri 必须显式注册,否则会返回 invalid_request

客户端(MVC/Web API)用 Microsoft.Identity.Web 实现 OIDC 认证最省事

.NET 5+ 官方推荐用 Microsoft.Identity.Web 包替代手写 AddOpenIdConnect,它自动处理 token 刷新、作用域协商、跨平台重定向等细节。

典型配置(以 ASP.NET Core MVC 为例):

builder.Services.AddMicrosoftIdentityWebAppAuthentication(builder.Configuration, "AzureAd")
    .EnableTokenAcquisitionToCallDownstreamApi(new string[] { "api://your-api-scope" })
    .AddInMemoryTokenCaches();

注意几个易错点:

  • "AzureAd"appsettings.json 中配置节名,不是硬编码字符串;节内必须包含 InstanceDomainClientIdClientSecret(或证书)、CallbackPath
  • 若对接自建 IdentityServer6,把 Instance 换成你的地址(如 https://localhost:5001),ClientId 必须与 IdentityServer 中 ClientClientId 完全一致
  • CallbackPath 默认是 /signin-oidc,IdentityServer 的 RedirectUris 列表里必须包含完整 URL(如 https://localhost:7001/signin-oidc),少一个斜杠都会报 unauthorized_client

IdentityServer6 中 Client 配置必须显式声明 AllowedGrantTypes 和 RedirectUris

常见错误是只配了 ClientIdClientName,结果登录后跳回客户端时报 invalid_redirect_uriunsupported_grant_type。这是因为 IdentityServer6 默认拒绝所有未明确定义的行为。

CodeWP
CodeWP

针对 WordPress 训练的AI代码生成器

下载

最小可行的 Client 配置示例(内存模式):

new Client
{
    ClientId = "mvc-client",
    ClientName = "MVC Client",
    AllowedGrantTypes = GrantTypes.Code, // 必须指定,不能留空
    ClientSecrets = { new Secret("secret".Sha256()) },
    RedirectUris = { "https://localhost:7001/signin-oidc" },
    PostLogoutRedirectUris = { "https://localhost:7001/signout-callback-oidc" },
    AllowedScopes = { "openid", "profile", "api1" }
}

特别注意:

  • GrantTypes.Code 对应 Authorization Code Flow(含 PKCE),这是 Web 应用唯一推荐方式;GrantTypes.Hybrid 已不推荐,GrantTypes.Implicit 在 IdentityServer6 中默认禁用
  • AllowedScopes 必须包含 openid,否则 OpenID Connect 协议不成立;若要获取用户信息,还得加 profile
  • 如果客户端是 Blazor WASM,RedirectUris 要写成 https://localhost:7001/authentication/login-callback,且需额外配置 RequirePkce = true

调试 OIDC 流程时,先看 /connect/authorize 返回的 HTML 是否含 error 参数

OIDC 登录失败往往卡在重定向链第一环:/connect/authorize。直接访问这个地址(带原始请求参数),浏览器会返回带错误提示的 HTML 页面,比如:

error=unauthorized_client&error_description=Invalid+client_id+or+redirect_uri

比抓包或查日志更快定位问题。常见触发条件:

  • 客户端发来的 client_id 在 IdentityServer 的 Clients 列表中不存在
  • redirect_uri 不在该 Client 的 RedirectUris 集合中(注意协议、端口、路径、末尾斜杠都要完全匹配)
  • 请求中带了 scope=offline_access,但 Client 未配置 AllowOfflineAccess = true
  • 用了 response_type=code id_token(Hybrid Flow),但 Client 的 AllowedGrantTypes 没包含 GrantTypes.Hybrid

真正难排查的是 HTTPS 与开发环境混合时的证书问题:本地用 https://localhost:5001 但没信任开发证书,导致 HttpClient 内部调用失败,错误却静默吞掉。这时候得在 IdentityServer 的 Startup 中临时启用 options.RequireHttpsMetadata = false(仅限开发)。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

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

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

180

2024.05.11

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

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

222

2025.12.18

json数据格式
json数据格式

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

436

2023.08.07

json是什么
json是什么

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

544

2023.08.23

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

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

317

2023.10.13

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

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

81

2025.09.10

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

351

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

326

2023.10.25

2026春节习俗大全
2026春节习俗大全

本专题整合了2026春节习俗大全,阅读专题下面的文章了解更多详细内容。

189

2026.02.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.2万人学习

C 教程
C 教程

共75课时 | 4.7万人学习

C++教程
C++教程

共115课时 | 17.3万人学习

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

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