我正在为我们的 Web 应用程序编写一个设置应用程序。其中一项任务是为内置的 SqlRoleProvider 设置数据库。我有我的脚本来使用aspnet_regsql.exe
-command 创建数据库,但现在我遇到了以编程方式创建默认角色和用户映射的麻烦。
我想做的事:
...
private class UserRole
{
public string Username { get; set; }
public string Role { get; set; }
}
...
const string applicationName = "foo";
var roles = new List<string> { "Administrator", "Editor" };
var userRoles =
new List<UserRole>
{
new UserRole {Username = "joli", Role = "Administrator"},
new UserRole {Username = "test", Role = "Editor"}
};
Roles.ApplicationName = applicationName;
foreach (var userRole in userRoles)
{
Roles.AddUserToRole(userRole.Username, userRole.Role);
}
...
问题是,在运行它时,我得到一个异常说“角色管理器未激活”,这当然是正确的,因为通常角色只能从 Web 应用程序处理。
我已经通过直接执行内置存储过程来解决这个问题,但我很好奇如何以编程方式解决这个问题。