【问题标题】:How to use Roles in ASP.NET MVC 5 web app with LocalDB?如何在带有 LocalDB 的 ASP.NET MVC 5 Web 应用程序中使用角色?
【发布时间】:2015-11-02 16:25:41
【问题描述】:

我想在 app_data 文件夹中的 LocalDB 数据库文件中管理具有默认 ASP.NET MVC 5 成员资格的用户和角色。如果它不存在,则会自动创建它。

我写了一个角色编辑器,但是当我尝试将角色应用到 Web API 时,如下所示:

[Authorize(Roles= "SystemAdmin")]

,角色管理器尝试调用数据库内的存储过程。

Invalid object name 'dbo.aspnet_SchemaVersions'.

此存储过程通常在由 aspnet_regsql 实用程序创建的完整 SQL Server 成员数据库中创建,但是 aspnet_regsql 实用程序仅在完整的 SQL Server 数据库上运行,并且不在 LocalDB 数据库上。

有没有办法告诉角色提供者不要进行这个存储过程调用,而不必从头开始编写角色提供者?我的数据库连接定义如下 -

<add name="DefaultConnection" connectionString="Data Source=(LocalDb)\v11.0;AttachDbFilename=|DataDirectory|\DefaultConnection.mdf;Initial Catalog=aspnetdb;Integrated Security=True" providerName="System.Data.SqlClient" />

【问题讨论】:

    标签: sql-server asp.net-mvc localdb


    【解决方案1】:

    我编写了一个替代解决方案 - 与 LocalDB 一起使用的自定义 RoleProvider。

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Security;
    using MyApp.Models;
    
    namespace MyAppNamespace
    {
    
        /// <summary>
        /// The purpose of this role provider is to support membership + roles in a MSSQL LocalDB.
        /// It works around the limitation of the standard SqlRoleProvider
        /// which requires stored procedures in a SQL Server database.
        /// </summary>
        public class CustomRoleProvider : RoleProvider
        {
            public override string ApplicationName { get; set; }
    
    
            public override string[] GetRolesForUser(string username)
            {
                using (var usersContext = new ApplicationDbContext())
                {
                    var user = usersContext.Users.FirstOrDefault(u => u.UserName.Equals(username, StringComparison.CurrentCultureIgnoreCase) || u.Email.Equals(username, StringComparison.CurrentCultureIgnoreCase));
    
    
                    if (user == null) return new string[] { };
    
                    var roles = from ur in user.Roles
                                from r in usersContext.Roles
                                where ur.RoleId == r.Id
                                select r.Name;
                    if (roles != null)
                        return roles.ToArray();
                    else
                        return new string[] { };
                }
    
            }
    
    
            public override void AddUsersToRoles(string[] usernames, string[] roleNames)
            {
                foreach(var userName in usernames)
                {
                    var roles = GetRolesForUser(userName);
                    foreach(var roleName in roleNames)
                    {
                        if (!roles.Contains<string>(roleName))
                        {
                            using (var usersContext = new ApplicationDbContext())
                            {
                                var user = usersContext.Users.FirstOrDefault(u => u.UserName.Equals(userName, StringComparison.CurrentCultureIgnoreCase));
                                if (user != null)
                                {
                                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
                                    if (role != null)
                                    {
                                        var userRole = new Microsoft.AspNet.Identity.EntityFramework.IdentityUserRole();
                                        userRole.RoleId = role.Id;
                                        userRole.UserId = user.Id;
                                        user.Roles.Add(userRole);
                                    }
                                }
                                usersContext.SaveChanges();
                            }
                        }
                    }
                }
            }
    
    
            public override string[] GetAllRoles()
            {
                using (var usersContext = new ApplicationDbContext())
                {
                    return usersContext.Roles.Select(r => r.Name).ToArray();
                }
            }
    
    
            public override bool IsUserInRole(string username, string roleName)
            {
                return this.GetRolesForUser(username).Contains(roleName);
            }
    
            public override void CreateRole(string roleName)
            {
                var role = new Microsoft.AspNet.Identity.EntityFramework.IdentityRole();
                role.Id = Guid.NewGuid().ToString();
                role.Name = roleName;
    
                using (var usersContext = new ApplicationDbContext())
                {
                    usersContext.Roles.Add(role);
                    usersContext.SaveChanges();
                }
    
            }
    
            public override bool DeleteRole(string roleName, bool throwOnPopulatedRole)
            {
                var usersInRole = GetUsersInRole(roleName);
                if (throwOnPopulatedRole)
                {
                    if (usersInRole.Length > 0)
                    {
                        throw new Exception("Role " + roleName + " is not empty");
                    }
                }
    
                var roleNameArray = new string[1];
                roleNameArray[0] = roleName;
                RemoveUsersFromRoles(usersInRole, roleNameArray);
    
                using (var usersContext = new ApplicationDbContext())
                {
                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
                    if (role != null)
                    {
                        usersContext.Roles.Remove(role);
                        usersContext.SaveChanges();
                        return true;
                    }
                    return false;
                }
    
            }
    
            public override bool RoleExists(string roleName)
            {
                using (var usersContext = new ApplicationDbContext())
                {
                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
                    return (role != null);
                }
            }
    
    
            public override void RemoveUsersFromRoles(string[] usernames, string[] roleNames)
            {
    
                foreach (var userName in usernames)
                {
                    var roles = GetRolesForUser(userName);
                    foreach (var roleName in roleNames)
                    {
                        if (!roles.Contains<string>(roleName))
                        {
                            using (var usersContext = new ApplicationDbContext())
                            {
                                var user = usersContext.Users.FirstOrDefault(u => u.UserName.Equals(userName, StringComparison.CurrentCultureIgnoreCase));
                                if (user != null)
                                {
                                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
                                    if (role != null)
                                    {
                                        var userRole = new Microsoft.AspNet.Identity.EntityFramework.IdentityUserRole();
                                        userRole.RoleId = role.Id;
                                        userRole.UserId = user.Id;
                                        user.Roles.Remove(userRole);
                                    }
                                }
                                usersContext.SaveChanges();
                            }
                        }
                    }
                }
            }
    
            public override string[] GetUsersInRole(string roleName)
            {
                using (var usersContext = new ApplicationDbContext())
                {
                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
    
                    var users = from ur in role.Users
                                from u in usersContext.Users
                                where ur.RoleId == u.Id
                                select u.UserName;
                    if (users != null)
                        return users.ToArray();
                    else
                        return new string[] { };
                }
            }
    
    
            public override string[] FindUsersInRole(string roleName, string usernameToMatch)
            {
                var regEx = new System.Text.RegularExpressions.Regex(usernameToMatch);
    
                using (var usersContext = new ApplicationDbContext())
                {
                    var role = usersContext.Roles.FirstOrDefault(r => r.Name.Equals(roleName, StringComparison.CurrentCultureIgnoreCase));
    
                    var users = from ur in role.Users
                                from u in usersContext.Users
                                where ur.RoleId == u.Id
                                && regEx.IsMatch(u.UserName)
                                select u.UserName;
                    if (users != null)
                        return users.ToArray();
                    else
                        return new string[] { };
                }
    
            }
        }
    
    }
    

    【讨论】:

    • 肯定有成千上万的人不得不写同样的东西,因为没有固定的解决方案?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-02-16
    • 2016-10-24
    • 1970-01-01
    • 2014-10-14
    相关资源
    最近更新 更多