当前位置: 首页>>代码示例>>C#>>正文


C# AuthRepository.UserRoles方法代码示例

本文整理汇总了C#中AuthRepository.UserRoles方法的典型用法代码示例。如果您正苦于以下问题:C# AuthRepository.UserRoles方法的具体用法?C# AuthRepository.UserRoles怎么用?C# AuthRepository.UserRoles使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在AuthRepository的用法示例。


在下文中一共展示了AuthRepository.UserRoles方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: GrantResourceOwnerCredentials

        public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
        {

            var allowedOrigin = context.OwinContext.Get<string>("as:clientAllowedOrigin");

            if (allowedOrigin == null) allowedOrigin = "*";

            context.OwinContext.Response.Headers.Add("Access-Control-Allow-Origin", new[] { allowedOrigin });
            var identity = new ClaimsIdentity(context.Options.AuthenticationType);
            using (AuthRepository _repo = new AuthRepository())
            {
                IdentityUser user = await _repo.FindUser(context.UserName, context.Password);

                if (user == null)
                {
                    context.SetError("invalid_grant", "The user name or password is incorrect.");
                    return;
                }
                else
                {
                    var roles = await _repo.UserRoles(user.Id);
                    identity.AddClaim(new Claim(ClaimTypes.Name, context.UserName));
                    foreach (var role in roles)
                    {
                        identity.AddClaim(new Claim(ClaimTypes.Role, role));
                    }
                    identity.AddClaim(new Claim("sub", context.UserName));

                    //AuthenticationProperties props = CreateProperties(user.UserName, Newtonsoft.Json.JsonConvert.SerializeObject(roles.Select(x => x.Value)));
                    //props.Dictionary.Add("as:client_id", (context.ClientId == null) ? string.Empty : context.ClientId);
                    //props.Dictionary.Add("userName", context.UserName);
                    var serializer = new System.Web.Script.Serialization.JavaScriptSerializer(); 
                    var props = new AuthenticationProperties(new Dictionary<string, string>
                    {
                        { 
                            "as:client_id", (context.ClientId == null) ? string.Empty : context.ClientId
                        },
                        { 
                            "userName", context.UserName
                        },
                        { 
                            "roles", serializer.Serialize(roles)
                        }
                    });

                    var ticket = new AuthenticationTicket(identity, props);
                    context.Validated(ticket);
                }
            }
        }
开发者ID:thangma,项目名称:AngularJSAuth,代码行数:50,代码来源:SimpleAuthorizationServerProvider.cs


注:本文中的AuthRepository.UserRoles方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。