Web API身份验证响应属性

时间:2014-10-27 13:22:02

标签: c# json asp.net-web-api asp.net-identity

我正在使用ASP.NET Web API开发Web服务。我正在使用ASP.NET Identity进行身份验证和令牌生成。我需要在令牌响应json中返回扩展属性。直到现在我能够返回一个扩展的字符串属性,在该属性中我发送一个通过将自定义类对象序列化为json而获得的json字符串。以下是我的身份验证提供程序代码:

public class ApplicationOAuthProvider : OAuthAuthorizationServerProvider
{
    public override async Task ValidateClientAuthentication(OAuthValidateClientAuthenticationContext context)
    {
        await Task.Run(() =>
        {
            context.Validated();
        });            
    }

    public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
    {
        await Task.Run(() =>
        {
            var loginResponse = new AccountManager().Login(context.UserName, context.Password);

            if (loginResponse == null)
            {
                context.SetError("invalid_grant", Resources.Messages.InvalidGrant);
                return;
            }

            var identity = new ClaimsIdentity(context.Options.AuthenticationType);

            IDictionary<string, string> data = new Dictionary<string, string>
            {
                { "userData", JsonConvert.SerializeObject(loginResponse) }
            };
            AuthenticationProperties properties = new AuthenticationProperties(data);

            Microsoft.Owin.Security.AuthenticationTicket ticket = new Microsoft.Owin.Security.AuthenticationTicket(identity, properties);
            context.Validated(ticket);
        });            
    }

    public override Task TokenEndpoint(OAuthTokenEndpointContext context)
    {
        foreach (KeyValuePair<string, string> property in context.Properties.Dictionary)
        {
            context.AdditionalResponseParameters.Add(property.Key, property.Value);
        }

        return Task.FromResult<object>(null);
    }
}

现在在我的回复中我有一个属性,例如"userData" : "<Json String>"而我想将一个json对象(不是json字符串)分配给userData。有可能吗?

1 个答案:

答案 0 :(得分:0)

我不建议将JSON对象放在票证属性中,这会大大增加令牌大小,并且每次请求都会传输此令牌。 也许在获得访问令牌后定义受保护的独立端点以执行此任务会更好。成功登录后,您将发出额外的Get请求,但您将保持令牌大小最小化。