如何通过令牌和角色在WEB API C#,SOAP架构中实现授权,通过使用存储过程的存储库?

问题描述 投票:0回答:1

如何通过使用存储过程和依赖注入的存储库,在WEB API C#,SOAP体系结构中通过令牌和角色实现授权?

public override void OnAuthorization(HttpActionContext actionContext)
{
    if (actionContext.Request.Headers.Authorization == null)
    {
        actionContext.Response = actionContext.Request.CreateResponse(HttpStatusCode.Unauthorized);
    }
    else
    {
        string autenticationToken = actionContext.Request.Headers.Authorization.Parameter;
        string decodeautenticationToken = Encoding.UTF8.GetString(Convert.FromBase64String(autenticationToken));
        string[] userNamePassworArray = decodeautenticationToken.Split(':');
        string username = userNamePassworArray[0];
        string password = userNamePassworArray[1];

        LoginModel model = new LoginModel();


        //validate user credentials and obtain user roles (return List Roles) 
        model.Roleslist = _serviceUsuario.ObtenerRoles(username, password);

        if (model.Roleslist !=null)
        {
            //this line takes a list of roles and divides them with a comma.
            string ListRoles = string.Join(",", model.Roleslist.Select(x => x.Roles));

            //bacic authentication
            Thread.CurrentPrincipal = new GenericPrincipal(new GenericIdentity(username), null);

我用以下方式尝试了它,但它不起作用

            //ClaimsIdentity oAuthIdentity = await model.Roleslist.GenerateUserIdentityAsync(userManager, OAuthDefaults.AuthenticationType);
            //ClaimsIdentity cookiesIdentity = await model.Roleslist.GenerateUserIdentityAsync(userManager, CookieAuthenticationDefaults.AuthenticationType);

            //it does not work
            var authTicket = new FormsAuthenticationTicket(1, username, DateTime.Now, DateTime.Now.AddMinutes(30), false, ListRoles);
            string encryptedTicket = FormsAuthentication.Encrypt(authTicket);
            var authCookie = new HttpCookie(FormsAuthentication.FormsCookieName, encryptedTicket);
            HttpContext.Current.Request.Cookies.Add(authCookie);

            //  HResult = 0x80004002 Message = You can not convert an object of type 'System.Security.Claims.ClaimsIdentity' to the type 'System.Web.Security.FormsIdentity'.
            FormsIdentity id = (FormsIdentity)HttpContext.Current.User.Identity;
            FormsAuthenticationTicket ticket = id.Ticket;
            string userData = ticket.UserData;
            string[] roles = userData.Split(',');
            HttpContext.Current.User = new GenericPrincipal(HttpContext.Current.User.Identity, roles);
        }
        else
        {
            actionContext.Response = actionContext.Request.CreateResponse(HttpStatusCode.Unauthorized, "El nombre de usuario o la contraseña no son correctos.");
        }
    }
}

我用以下方式尝试了它,但它不起作用

    public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
    {
        var userManager = context.OwinContext.GetUserManager<ApplicationUserManager>();
        LoginModel model = new LoginModel();
        //validate user credentials //valida las credenciales de usuario  
        //model.usuario = _serviceUsuario.Login(context.UserName, context.Password);//bool
        //validate user credentials and obtain user roles //validar las credenciales de usuario y obtener roles de usuario
        model.Roleslist = _serviceUsuario.ObtenerRoles(context.UserName, context.Password);//List

        //ApplicationUser user = await userManager.FindAsync(context.UserName, context.Password);

        if (model.Roleslist == null)
        {
            context.SetError("invalid_grant", "El nombre de usuario o la contraseña no son correctos.");
            return;
        }
api web
1个回答
0
投票

我设法使用没有实体框架的Token实现身份验证,该实现是基于存储过程和角色的验证。代码如下:

public class CredentialsAuthorizationServerProvider : OAuthAuthorizationServerProvider
{
    // ...

    public override async Task GrantResourceOwnerCredentials(OAuthGrantResourceOwnerCredentialsContext context)
    {
        context.OwinContext.Response.Headers.Add("Access-Control-Allow-Origin", new[] { "*" });
        LoginModel model = new LoginModel();

        //validate user credentials and obtain user roles (return List Roles) 
        //validar las credenciales de usuario y obtener roles de usuario
        var user = model.User = _serviceUsuario.ObtenerUsuario(context.UserName, context.Password);
        if (user == null)
        {
            context.SetError("invalid_grant", "El nombre de usuario o la contraseña no son correctos.cod 01");
            return;
        }

        var stringRoles = user.Roles.Replace(" ", "");
        string[] roles = stringRoles.Split(',');
        var identity = new ClaimsIdentity(context.Options.AuthenticationType);

        foreach (var Rol in roles)
        {
            identity.AddClaim(new Claim(ClaimTypes.Role, Rol));
        }

        identity.AddClaim(new Claim(ClaimTypes.Name, context.UserName));

        AuthenticationProperties properties = CreateProperties(context.UserName);
        var ticket = new AuthenticationTicket(identity, properties);

        context.Validated(ticket);
    }
}

为基于OAuth的流配置应用程序

PublicClientId = "self";
OAuthOptions = new OAuthAuthorizationServerOptions
{
    TokenEndpointPath = new PathString("/Token"),
    //Provider = new ApplicationOAuthProvider(PublicClientId),
    Provider = new CredentialsAuthorizationServerProvider(PublicClientId),
    AuthorizeEndpointPath = new PathString("/api/Account/ExternalLogin"),
    AccessTokenExpireTimeSpan = TimeSpan.FromHours(1),
    // En el modo de producción establezca AllowInsecureHttp = false
    AllowInsecureHttp = true
};

// Permitir que la aplicación use tokens portadores para autenticar usuarios
//app.UseOAuthBearerTokens(OAuthOptions);
app.UseOAuthAuthorizationServer(OAuthOptions);

启动

public partial class Startup
{
    public void Configuration(IAppBuilder app)
    {
        var config = new HttpConfiguration();
        WebApiConfig.Register(config);
        ConfigureAuth(app);
        var authOptions = new OAuthBearerAuthenticationOptions()
        {
            AuthenticationMode = Microsoft.Owin.Security.AuthenticationMode.Active
        };
        app.UseOAuthBearerAuthentication(authOptions);
        app.UseWebApi(config);
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.