我一直在按照此处的教程设置授权服务器,与我的客户端应用程序分开。 http://bitoftech.net/2014/06/01/token-based-authentication-asp-net-web-api-2-owin-asp-net-identity/
我可以让他的榜样起作用,但我觉得我错过了申请的几个步骤。
我希望这个授权服务器提供oauth令牌,这些令牌将由一个单独的项目(可能还有多个其他项目)用于对用户进行身份验证。我理解这一点是将授权逻辑和业务逻辑分开,但我不确定如何将auth服务器上创建的用户与应用程序上的用户实际配对。
例如,当用户第一次创建帐户时,他们会将其用户名/密码发送到授权服务器。应用程序在什么时候还会创建自己的用户信息(空配置文件和设置等),然后如何将应用程序的userID与授权信息一起存储?我已经尝试在auth服务器上添加客户端UserID作为声明,但我不确定我是否完全理解这意味着什么,或者这是否是正确的方法。
基本上,我认为我应该能做的,但不知道怎么做,在我的ASP.Net WebApi应用程序中,它应该接受授权:Bearer<令牌>标题,并以某种方式能够从授权服务器获取UserID(与该特定应用程序相关)。第二个不相关的应用程序应该能够接受相同的访问令牌,并从auth服务器获得自己的UserID(假设用户拥有两个应用程序的帐户)。
我是以正确的方式看待这个吗?如何将不同应用程序的UserID与在auth服务器上创建的用户相关联?
答案 0 :(得分:0)
假设我了解您正在尝试正确执行的操作,如果您正在使用Microsoft的OAuth Owin实现,那么您应该能够覆盖OAuthAuthorizationServerProvider,然后覆盖相应的格兰特*()。
有关详细信息,请参阅http://www.asp.net/aspnet/overview/owin-and-katana/owin-oauth-20-authorization-server。
如果您只是使用ResourceOwner授权,那么它非常直接:
public override Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
{
var user = ...;
if (!PasswordProvider.ValidatePassword(context.Password, user.Password))
{
context.SetError("invalid_grant", "The password is incorrect.");
return Task.FromResult<object>(null);
}
// Build Claims Identity
var identity = new ClaimsIdentity(OwinAuthConfig.OAuthAuthorizationOptions.AuthenticationType);
identity.BuildClaims(user);
// Create the Properties
var properties = CreateProperties(user);
// Create the ticket and process it.
var ticket = new AuthenticationTicket(identity, properties);
context.Validated(ticket);
return Task.FromResult<object>(null);
}
构建声明的地方如下:
public static class ApplicationOAuthProviderHelper
{
public static void BuildClaims(this ClaimsIdentity identity, User user)
{
var claims = new List<Claim>
{
new Claim(ClaimTypes.Name, user.Username),
new Claim(ClaimTypes.NameIdentifier, user.UserId.ToString())
};
// Get custom claims, like user app ids.
// ex. Claim { ClaimType = "app1/UserId", Value = "34242" }
var externalAppClaims = MagicalFunctionThatGetsExternalClaims(user);
foreach(var claim in externalAppClaims)
{
claims.Add(new Claim(claim.ClaimType, claim.Value));
}
identity.AddClaims(claims);
}
}
然后可以在Web API控制器中使用它:
var userIdString = (User.Identity as ClaimsIdentity).FindFirst("app1/UserId");
如果这不能回答你的问题,请告诉我!