应使用Microsoft.AspNetCore.Authentication.OpenIdConnect或IdentityModel等成熟封装,避免手写OAuth2.0流程;第三方回调地址须与注册完全一致;access_token不可直接用作身份凭证,需通过userinfo端点获取用户标识并创建本地会话;PKCE为现代OAuth2.0强制要求,.NET 6+默认启用但需确认配置。OAuth2.0在C#里不是靠自己手写协议流程你不需要手动拼authorization头、解析code、再post换access_token------.net生态早有成熟封装,硬撸只会掉进重定向丢失、pkce漏配、token刷新失败这些坑。关键判断:用Microsoft.AspNetCore.Authentication.OpenIdConnect(Web应用)或IdentityModel(后台服务/桌面端)就够了,别碰HttpClient裸调。ASP.NET Core MVC/Razor Pages:走AddOpenIdConnect + SignInAsync,它自动处理授权码流转、state校验、cookie签发.NET 6+ Minimal API 或 WinForms/WPF:用IdentityModel.OidcClient,它封装了PKCE、token存储、刷新逻辑千万别用WebClient或原始HttpClient去GET授权URL再手动解析回调参数------state防CSRF、code_verifier校验、重定向URI匹配全得自己兜底,99%的人第一次就漏掉code_challenge_method=S256第三方登录回调地址必须和注册时完全一致哪怕多一个/、少一个https、端口没写对,授权服务器直接拒绝返回code,浏览器卡在白页,控制台连错误都看不到。常见错误现象:invalid_redirect_uri、redirect_uri_mismatch、或者根本没跳转回你的站点,停留在第三方登录页不动。检查第三方平台(微信/支付宝/GitHub)后台填的Authorized redirect URIs,必须和你代码里CallbackPath拼出来的完整URL一模一样本地开发时,https://localhost:5001/signin-oidc和https://localhost:5001/signin-oidc/是两个不同URIDocker或反向代理后,如果用了Nginx/Apache,确保X-Forwarded-Proto和X-Forwarded-Host头被正确传递,否则HttpContext.Request.Scheme读出来还是http,生成的回调地址就错access_token拿回来之后不能直接当用户身份用access_token是给调第三方API用的,不是你系统里的登录凭证。把它存进Session或JWT里发给前端,等于把第三方的钥匙交出去,一旦泄露或过期,用户就登不进你的系统。正确做法:拿到access_token后,立刻用它请求第三方的userinfo端点(比如https://api.weixin.qq.com/sns/userinfo),提取openid或sub作为唯一标识,在你自己的数据库建用户记录,再发你自己的session cookie或JWT。 Mokker AI AI产品图添加背景
相关推荐
码云骑士8 分钟前
13-列表append的底层真相(上)-listobject源码中的预分配策略huangdong_10 分钟前
京东商品图片视频批量下载与m3u8视频合并技术完整实现方案倒流时光三十年19 分钟前
PostgreSQL CASE 条件表达式详解浦信仿真大讲堂26 分钟前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍字节跳动数据平台41 分钟前
营销视频进入工业化时代,火山引擎多模态数据湖如何助力多米实现内容生产提效 100+ 倍xufengzhu43 分钟前
第三方 Python 库 Loguru 的进阶实战健康平安的活着1 小时前
mysql中数据库脚本太大,通过脚本命令修改db名称cfm_29141 小时前
JVM新一代垃圾收集器深度解析:G1与ZGC倒流时光三十年1 小时前
PostgreSQL COALESCE 条件表达式函数详解让我上个超影吧2 小时前
Claude code:Hooks