首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >System.Security.Claims.ClaimType角色不匹配

System.Security.Claims.ClaimType角色不匹配
EN

Stack Overflow用户
提问于 2017-02-11 06:32:09
回答 1查看 992关注 0票数 3

只是试图理解一个问题,在我的头脑中,这似乎是一个错误的微软System.Security dll,但可能是我做错了一些事情。

我正在尝试自定义实现JWT令牌。我创建索赔和令牌:

代码语言:javascript
复制
var claimsIdentity = new ClaimsIdentity(new List<System.Security.Claims.Claim>()
            {
                new System.Security.Claims.Claim(ClaimTypes.Sid, "1"),
                new System.Security.Claims.Claim(ClaimTypes.Role, "1"),
            },"Custom");


var securityTokenDescriptor = new SecurityTokenDescriptor()
            {
                AppliesToAddress = Keys.Core.WebsiteDomain,
                TokenIssuerName = Keys.Core.WebsiteDomain,
                Subject = claimsIdentity,
                SigningCredentials = signingCredentials,
            };

            var tokenHandler = new JwtSecurityTokenHandler();
            var plainToken = tokenHandler.CreateToken(securityTokenDescriptor);
            var signedAndEncodedToken = tokenHandler.WriteToken(plainToken);

            return signedAndEncodedToken;

然后检索令牌和用户(SID)和角色值:

代码语言:javascript
复制
var roleId = stream.Claims.SingleOrDefault(x => x.Type == ClaimTypes.Role).Value;
var userId = stream.Claims.SingleOrDefault(x => x.Type == ClaimTypes.Sid).Value;

验证功能:

代码语言:javascript
复制
private static JwtSecurityToken Validate(string signedAndEncodedToken)
        {
            var tokenHandler = new CustomJwtSecurityTokenHandler();

            var plainTextSecurityKey = Keys.Security.TokenSecret;
            var signingKey = new InMemorySymmetricSecurityKey(
                Encoding.UTF8.GetBytes(plainTextSecurityKey));

            var tokenValidationParameters = new TokenValidationParameters()
            {
                ValidateIssuer = false,
                ValidateAudience = false,
                IssuerSigningKey = signingKey
            };

            SecurityToken validatedToken;
            tokenHandler.ValidateToken(signedAndEncodedToken, tokenValidationParameters, out validatedToken);
            var jwtToken = validatedToken as JwtSecurityToken;
            return validatedToken as JwtSecurityToken;
        }

现在,我的UserID (ClaimType.SID)似乎返回正确,但我的RoleId (ClaimType.Role)作为不存在返回。如果我更改了x.Type ==的“角色”,它就会正常工作。

对Claim.Type SID的检查显示为:http://schemas.xmlsoap.org/ws/2005/05/identity/claims/sid

但是Claim.Type角色显示为:角色。

ClaimTypes.Role具有完整的架构路径。

这是个窃听器还是我漏掉了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-05-15 16:44:32

我意识到有些时候已经过去了,但作为一个对此感到惊讶的人,我确实在JwtSecurityToken.Claims属性上遇到了这样的评论:

根据Claim.Type JwtSecurityTokenHandler.InboundClaimTypeMap的说法,的索赔将不会被翻译成。

因此,如果您想在解码令牌中搜索时使用ClaimTypes,只需在字典中运行它,就可以知道您没有疯或者做了任何错误的事情。

代码语言:javascript
复制
        Assert.Equal(
            "Nicholas Piasecki", 
            parsedToken
                .Claims
                .Single(x =>
                {
                    var map = JwtSecurityTokenHandler.DefaultInboundClaimTypeMap;

                    if (map.TryGetValue(x.Type, out var mapped))
                    {
                        return mapped == ClaimTypes.GivenName;
                    }

                    return false;
                })
                .Value);
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42173057

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档