如何访问使用Identity Server授权的ASPnet核心应用程序中的自定义声明

How to access custom claim in aspnet core application authorized using Identity Server(如何访问使用Identity Server授权的ASPnet核心应用程序中的自定义声明)
本文介绍了如何访问使用Identity Server授权的ASPnet核心应用程序中的自定义声明的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在遵循Identity Server快速入门模板,并尝试设置以下内容

  • 身份服务器ASPnet核心应用
  • MVC客户端,它向IS4进行身份验证,并调用受保护的API资源WebAPI客户端。

ApplicationUser有一个额外的列,我将其添加到来自ProfileService的索赔中,如下所示:

        public async Task GetProfileDataAsync(ProfileDataRequestContext context)
        {
            var sub = context.Subject.GetSubjectId();
            var user = await _userManager.FindByIdAsync(sub);
            if (user == null)
                return;

            var principal = await _claimsFactory.CreateAsync(user);
            if (principal == null)
                return;

            var claims = principal.Claims.ToList();

            claims.Add(new Claim(type: "clientidentifier", user.ClientId ?? string.Empty));

            // ... add roles and so on

            context.IssuedClaims = claims;
        }

最后是MVC客户端APP中的配置ConfigureServices方法:

            JwtSecurityTokenHandler.DefaultMapInboundClaims = false;

            services.AddAuthentication(options =>
            {
                options.DefaultAuthenticateScheme = CookieAuthenticationDefaults.AuthenticationScheme;
                options.DefaultScheme = "Cookies";
                options.DefaultChallengeScheme = "oidc";
            }).AddCookie(CookieAuthenticationDefaults.AuthenticationScheme)
            .AddOpenIdConnect("oidc", options =>
            {
                options.Authority = "http://localhost:5000";
                options.RequireHttpsMetadata = false;

                options.ClientId = "mvc";
                options.ClientSecret = "mvc-secret";
                options.ResponseType = "code";

                options.SaveTokens = true;

                options.Scope.Add("openid");
                options.Scope.Add("profile");
                options.Scope.Add("offline_access");

                options.Scope.Add("api1");

                options.GetClaimsFromUserInfoEndpoint = true;

                options.ClaimActions.MapUniqueJsonKey("clientidentifier", "clientidentifier");
            });

GetClaimsFromUserInfoEndpoint设置为true时,我可以访问User.Identity中的自定义声明,但这会导致对ProfileService进行2次调用。

如果我删除或设置为False,则此声明仍然是Access_Token的一部分,但不是id_Token的一部分,然后我无法从上下文用户访问此特定声明。

有没有更好的方法可以从用户主体访问此声明,而不会导致2次调用(就像现在一样)?或者从上下文中读取Access_Token,并在检索到令牌后更新用户声明?

谢谢:)

推荐答案

发现标识服务器中的Client对象具有执行该工作的属性:

        //
        // Summary:
        //     When requesting both an id token and access token, should the user claims always
        //     be added to the id token instead of requring the client to use the userinfo endpoint.
        //     Defaults to false.
        public bool AlwaysIncludeUserClaimsInIdToken { get; set; }

如将客户端的lib元数据设置为True中所述,客户端不必从端点重新获取声明

谢谢大家:)

这篇关于如何访问使用Identity Server授权的ASPnet核心应用程序中的自定义声明的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)