zoukankan      html  css  js  c++  java
  • IdentityServer4【Topic】之保护APIs

    Protecting APIs 保护api

    默认情况下IdentityServer将access token发布成JWT(json web token)格式的。

    现在,每个相关的平台都支持验证JWT令牌,这里可以找到一个很好的JWT库列表。流行的库如:

    保护基于Asp.net core的api需要做的事情就是在DI中配置jwt bearer authentication handler。并且在管道上面添加authentication中间件:

    public class Startup
    {
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddMvc();
    
            services.AddAuthentication(JwtBearerDefaults.AuthenticationScheme)
                .AddJwtBearer(options =>
                {
                    // base-address of your identityserver
                    options.Authority = "https://demo.identityserver.io";
    
                    // name of the API resource
                    options.Audience = "api1";
                });
        }
    
        public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
        {
            app.UseAuthentication();
            app.UseMvc();
        }
    }

    The IdentityServer authentication handler

    我们的身份验证处理程序(指IdentityServer4中提供的handler)与上面的处理程序(handler)有相同的用途(实际上它在内部使用Microsoft JWT库),但是添加了一些额外的特性:

    • support for both JWTs and reference tokens //同时支持JWTs和引用token
    • extensible caching for reference tokens//为引用token支持缓存
    • unified configuration model//统一了配置模型
    • scope validation//范围的检查

    对于最简单的场景,我们的handler配置过程看起来和上面的代码片段非常相似:

    public class Startup
    {
        public void ConfigureServices(IServiceCollection services)
        {
            services.AddMvc();
            //api保护是在api里面做的,需要引入IdentityServer4.AccessTokenValidation这个nuget包。比如下面这个参数来自包中
            services.AddAuthentication(IdentityServerAuthenticationDefaults.AuthenticationScheme)
                .AddIdentityServerAuthentication(options =>
                {
                    // base-address of your identityserver
                    options.Authority = "https://demo.identityserver.io";
    
                    // name of the API resource
                    options.ApiName = "api1";
                });
        }
    
        public void Configure(IApplicationBuilder app, ILoggerFactory loggerFactory)
        {
            app.UseAuthentication();
            app.UseMvc();
        }
    }

    Supporting reference tokens支持引用token

    如果进来的令牌不是JWT,我们的中间件将会联系发现文档(discovery document,就是./well-known/openid-configuration端点)中找到的内省端点(introspection endpoint)来验证令牌。由于自省端点需要认证,所以你需要提供配置的API秘密,例如:

    .AddIdentityServerAuthentication(options =>
    {
        // base-address of your identityserver
        options.Authority = "https://demo.identityserver.io";
    
        // name of the API resource
        options.ApiName = "api1";
        options.ApiSecret = "secret";
    })

    通常,你不希望为每个传入的请求对自省端点进行一次往返。中间件有一个内置的缓存,可以这样启用:

    .AddIdentityServerAuthentication(options =>
    {
        // base-address of your identityserver
        options.Authority = "https://demo.identityserver.io";
    
        // name of the API resource
        options.ApiName = "api1";
        options.ApiSecret = "secret";
        options.EnableCaching = true;
        options.CacheDuration = TimeSpan.FromMinutes(10); // that's the default
    })
    //处理程序将使用在DI容器中注册的任何i分布式缓存实现(例如标准的memory分布式缓存)。

    Validating scopes检查请求的范围

    ApiName属性(上面的代码提到的这个属性)检查传过来的token的audience(或者叫做aud)的claim,查看是否匹配。

    在IdentityServer中你可以将API继续细分成多个范围。如果你需要这种粒度的分化那么你可以使用ASP.NET Core 中的授权策略(authorization policy system)来检查scope:

    • 创建全局的策略(基于MVCOpitons进行配置,添加到过滤器上)
    services.AddMvcCore(options =>
        {
            // require scope1 or scope2。create是扩展方法,在内部
           //调用了requireclaim。
            var policy = ScopePolicy.Create("scope1", "scope2");
            options.Filters.Add(new AuthorizeFilter(policy));
        })
        .AddJsonFormatters()
        .AddAuthorization();
    • 构建一个范围策略(基于AuthorizationOptions进行构建)
    services.AddAuthorization(options =>
    {
        options.AddPolicy("myPolicy", builder =>
        {
            // 来自identityserver的扩展方法
            builder.RequireScope("scope1");
            // and require scope2 or scope3
            builder.RequireScope("scope2", "scope3");
        });
    });
  • 相关阅读:
    C语言清空输入缓冲区的N种方法对比(转)
    UNIX网络编程——socket的keep-alive(转)
    UNIX网络编程——套接字选项(心跳检测、绑定地址复用)(转)
    UNIX网络编程——客户/服务器心搏函数 (转)
    TCP心跳 | TCP keepAlive(转)
    linux下使用adb查看android手机的logcat
    linux 常用查看设备命令(转)
    Spring AOP 详解
    HDU 2222 AC自动机 裸题
    大声说出我爱你—英语发音学习总结
  • 原文地址:https://www.cnblogs.com/pangjianxin/p/9279506.html
Copyright © 2011-2022 走看看