目的:创建IdentityServer 并通过PostMan验证获取token

第一次配置如下
  1. public class Config
  2. {
  3. public static IEnumerable<ApiResource> GetResource()
  4. {
  5. return new List<ApiResource>
  6. { new ApiResource("api","My Api") };
  7. }
  8. public static IEnumerable<Client> GetClients()
  9. {
  10. return new List<Client> { new Client()
  11. {
  12. ClientId="client",
  13. AllowedGrantTypes=GrantTypes.ClientCredentials,
  14. ClientSecrets={ new Secret("secret".Sha256())},
  15. AllowedScopes={"api"}
  16. } };
  17. }
  18. }

PostMan的请求如图

http://localhost:5000/connect/token

结果显示 请求无效 参照教程 >https://www.cnblogs.com/monster17/p/13261647.html 得知是因为传参格式的问题

  • 1.我们将Body改为 格式
  • 2.加参数<AllowedScopes: api> 【指定的api为配置Config中apiresource的名称】 再次请求

    如图

结果又显示scope无效 【这里懵逼了很久 明明Config中apiResource的name 和client中AllowedScopes的接口是一致的】

但是参照报错 一定是scop的问题 于是去找了一下官方文档关于API Resources 的使用

https://identityserver4.readthedocs.io/en/latest/topics/resources.html?highlight=apiresource#api-resources

参照原文



这里也便可以理解 问题所在了。 apiResource并不等同于scope 它相当于是scopes集合的统称 实现了scope的分组【但具体的scope还是要进行设置的 我们先前的Config 缺少具体scope =。= 真是令人头大】

先参照例子理解一下

  1. //创建多个scope
  2. {
  3. return new List<ApiScope>
  4. {
  5. // invoice API specific scopes
  6. new ApiScope(name: "invoice.read", displayName: "Reads your invoices."),
  7. new ApiScope(name: "invoice.pay", displayName: "Pays your invoices."),
  8. // customer API specific scopes
  9. new ApiScope(name: "customer.read", displayName: "Reads you customers information."),
  10. new ApiScope(name: "customer.contact", displayName: "Allows contacting one of your customers."),
  11. // shared scope
  12. new ApiScope(name: "manage", displayName: "Provides administrative access to invoice and customer data.")
  13. };
  14. }
  15. //调取时 将多个scope的Name加参时 可能会很长很长 为了方便 我们将scope 进行分组 后期可直接调用**统称** 这里分成两组
  16. public static readonly IEnumerable<ApiResource> GetApiResources()
  17. {
  18. return new List<ApiResource>
  19. {
  20. new ApiResource("invoice", "Invoice API")//设置每组scopes的统称
  21. {
  22. Scopes = { "invoice.read", "invoice.pay", "manage" }//设置每组scope具体名称
  23. },
  24. new ApiResource("customer", "Customer API")
  25. {
  26. Scopes = { "customer.read", "customer.contact", "manage" }
  27. }
  28. };
  29. }

再来回头看看我们的Config 修改如下

  1. public class Config
  2. {
  3. public static IEnumerable<ApiResource> GetApiResources()
  4. {
  5. return new List<ApiResource>() {
  6. new ApiResource("api", "My api") { Scopes={"api1","api2"} //将具体的scopes 归为一组 统称为api
  7. } };
  8. }
  9. //创建具体的scope
  10. public static IEnumerable<ApiScope> GetApiScopes()
  11. {
  12. return new List<ApiScope> {
  13. new ApiScope("api1","My first api"),
  14. new ApiScope("api2","My second api")};
  15. }
  16. public static IEnumerable<Client> GetClients()
  17. {
  18. return new List<Client>() { new Client {
  19. ClientId="client",
  20. AllowedGrantTypes=GrantTypes.ClientCredentials,
  21. ClientSecrets={new Secret("secret".Sha256()) },
  22. AllowedScopes={ "api1","api2"}//此处一定要配置具体的scope名称 外部调用可直接配置为 api【统称】
  23. } };
  24. }

用PostMan验证一下

成功了 emmmm 又是美好的一天【还是要多读源文档e =.=】

补充 获取Refresh_token

GetClients配置修改如下

结果

.Net Core WebApi(三)--使用 IdentityServer4 4.1.1 踩坑记录的更多相关文章

  1. ASP.Net Core Web Api 使用 IdentityServer4 最新版 踩坑记录

    辅助工具 日志追踪包 : Serilog.AspNetCore 源码查看工具 : ILSpy 项目环境 ###: ASP.NetCore 3.1 IdentityServer4 4.0.0+ 主题内容 ...

  2. .net core建站踩坑记录

    系统:win10 VS版本:2017 .NET Core 版本: 1.1 零.读取配置文件 参考:http://www.tuicool.com/articles/QfYVBvi 此版本无需添加其他组件 ...

  3. Asp.Net Core Identity+EFCore + Mysql踩坑记录

    搭建基础框架准备试试传说中的Identity,本以为很顺利,结果一路踩了N多坑 遂就把过程记录下来.方便自己以后查看,也希望能帮到遇到同样问题的朋友. 1.首先,引入Identity需要的类库,还有M ...

  4. .NET CORE 2.0 踩坑记录之ConfigurationManager

    在之前.net framework 中使用的ConfigurationManager还是很方便的,不过在.NET CORE 2.0中SDK默认已经不存在ConfigurationManager. 那么 ...

  5. 关于.net core 在docker中监听地址设置踩坑记

    1.今天在做docker容器的时候发现如果将.net core 内部监听地址设置为localhost:8888. 2.在docker build -p 6444:8888 运行容器后,外部通过6444 ...

  6. .net Core发布至IIS完全手册带各种踩坑

    服务器环境配置 和各位大爷报告一下我的服务器环境 : Windows Server 2012 iis 8 小插曲开始: 运维大哥在昨天给了我一台新的server 0环境开始搭建 . 并且没有安装任何的 ...

  7. Kubernetes-Service介绍(三)-Ingress(含最新版安装踩坑实践)

    前言 本篇是Kubernetes第十篇,大家一定要把环境搭建起来,看是解决不了问题的,必须实战. Kubernetes系列文章: Kubernetes介绍 Kubernetes环境搭建 Kuberne ...

  8. 在 ASP.NET Core 中使用 MySql 踩坑记录

    使用 Pomelo.EntityFrameworkCore.MySql 生成 MySQL 数据库 关于如何使用请查看项目文档即可 组件地址:https://github.com/PomeloFound ...

  9. net core 踩坑记录

    静态文件要放到wwwroot目录中才能访问 linux服务器部署运行报错 System.Net.Http.HttpRequestException: The SSL connection could ...

随机推荐

  1. C语言:#error命令,阻止程序编译

    #error 指令用于在编译期间产生错误信息,并阻止程序的编译,其形式如下: #error error_message 例如,我们的程序针对 Linux 编写,不保证兼容 Windows,那么可以这样 ...

  2. C语言:宏完美定义

    #include <stdio.h> #define M (n*n+3*n) #define M1 n*n+3*n int main(){ int sum, n; printf(" ...

  3. 一行代码打印python之禅

    就这一句: import this 输出: The Zen of Python, by Tim Peters Beautiful is better than ugly. Explicit is be ...

  4. 深入理解javascript按值传递与按引用传递

    https://segmentfault.com/a/1190000012829900

  5. apt-key Debian packages密钥管理命令

    adv子命令 Pass advanced options to gpg. With adv --recv-key you can e.g. download key from keyservers  ...

  6. element取消全局loading

    背景 前两天在开发一个管理后台项目时, 遇到了一个问题,后端接口返回特别慢,由于该接口调用的是第三方API,无法通过后端去处理.此时想到用loading动画,但随之而来也产生了不少问题, 在此记录一下 ...

  7. IntelliJ IDEA2021.2 常用快捷键汇总总结

    Java开发环境:Windows10 64bit+JDK8+IDEA2021.2 =========================================================== ...

  8. WIN XP SP2系统经常性死机问题解决历程

    如题: 1.初始时,XP还能进入系统,等系统3分钟左右,鼠标熄灭,键盘无反应,查看资源管理器CPU 100%,内存占用不高. 2.现象初步分析: a.怀疑是病毒占用CPU 100%,于是下载360安全 ...

  9. java标识符,关键字,注释及生成Doc文档

    # java语法基础 ## 标识符,关键字与注释 ### 标识符 1.类名,变量名,方法名都称为标识符. 2.命名规则:(1):所有的标识符都应该以字母(AZ,或者az)美元符($)或者下划线(_)开 ...

  10. IDEA使用Tomcat时控制台乱码的解决方案>从零开始学JAVA系列

    IDEA使用Tomcat时控制台乱码的解决方案 解决方案1,修改启动时虚拟机参数 解决方案2,修改idea的设置 解决方案3,修改idea配置文件 在最后添加一行 '-Dfile.encoding=U ...