gpt4 book ai didi

asp.net-mvc-4 - 具有自定义角色的 MVC 4 Intranet 身份验证

转载 作者:行者123 更新时间:2023-12-02 14:05:24 27 4
gpt4 key购买 nike

我花了一些时间搜索并发现了很多令人困惑的答案,因此我将在这里发布以进行澄清。

我正在使用MVC4 VS2012创建一个使用域身份验证的Intranet站点。一切正常。但是,为了管理有权访问此 Web 应用程序不同区域的用户,我不喜欢使用我无法管理的 AD 组,该 Web 应用程序的用户也无法管理。

还有其他选择吗?我认为这将涉及关联/存储属于自定义角色的域名并使用授权属性来控制访问。

[Authorize(Roles = "Managers")]

任何人都可以建议最好的模式或为我指出正确的方向吗?

我看到类似的解决方案 link ,但我仍然不确定如何针对存储的角色列表使用它并根据这些角色验证用户。谁能详细说明这个解决方案是否有效?

        protected void Application_AuthenticateRequest(object sender, EventArgs args)
{
if (HttpContext.Current != null)
{
String[] roles = GetRolesFromSomeDataTable(HttpContext.Current.User.Identity.Name);

GenericPrincipal principal = new GenericPrincipal(HttpContext.Current.User.Identity, roles);

Thread.CurrentPrincipal = HttpContext.Current.User = principal;
}
}

最佳答案

我将此配置与 SQL Server 和 MVC3 一起使用。

Web.config:

<system.web>
<roleManager enabled="true" defaultProvider="SqlRoleManager">
<providers>
<clear />
<add name="SqlRoleManager" type="System.Web.Security.SqlRoleProvider" connectionStringName="SqlRoleManagerConnection" applicationName="YourAppName" />
</providers>
</roleManager>

...

<authentication mode="Windows" />

...

<connectionStrings>

<add name="SqlRoleManagerConnection" connectionString="Data Source=YourDBServer;Initial Catalog=AppServices;Integrated Security=True;" providerName=".NET Framework Data Provider for OLE DB" />
</connectionStrings>

初始化角色:

Global.asax.cs

using System.Web.Security;

////
protected void Application_Start()
{

//You could run this code one time and then manage the rest in your application.
// For example:

// Roles.CreateRole("Administrator");
// Roles.AddUserToRole("YourDomain\\AdminUser", "Administrator");


Roles.CreateRole("CustomRole");

Roles.AddUserToRole("YourDomain\\DomainUser", "CustomRole");

}

在你的 Controller 中

[Authorize(Roles ="CustomRole")]
public class HomeController : Controller
{

管理用户

 public class Usuario
{
public string UserName { get; set; }
public string RoleName { get; set; }
public string Name { get; set; }
public const string Domain = "YourDomain\\";


public void Delete()
{
Roles.RemoveUserFromRole(this.UserName, this.RoleName);
}

public void Save()
{
if (Roles.IsUserInRole(Usuario.Domain + this.UserName, this.RoleName) == false)
{
Roles.AddUserToRole(Usuario.Domain + this.UserName, this.RoleName);
}
}
}

用户类别

public class Usuarios : List<Usuario>
{

public void GetUsuarios() //Get application's users
{

if (Roles.RoleExists("CustomRole"))
{
foreach (string _usuario in Roles.GetUsersInRole("CustomRole"))
{
var usuario = new Usuario();
usuario.UserName = _usuario;
usuario.RoleName = "CustomRole";
this.Add(usuario);
}
}
//

public void GetUsuariosRed() //Get Network Users (AD)
{
var domainContext = new PrincipalContext(ContextType.Domain);
var groupPrincipal = GroupPrincipal.FindByIdentity(domainContext, IdentityType.SamAccountName, "Domain Users");

foreach (var item in groupPrincipal.Members)
{
var usuario = new Usuario();
usuario.UserName = item.SamAccountName;
usuario.Name = item.Name;
this.Add(usuario);
}

}

您可以像这样创建一个“管理” Controller 来管理用户:

[Authorize(Roles = "AdminCustomRole")]
public class AdminController : Controller
{

//

public ActionResult Index()
{

var Usuarios = new Usuarios();
Usuarios.GetUsuarios();
return View(Usuarios);

}

[HttpGet]
public ActionResult CreateUser()
{

var Usuarios = new Usuarios();
Usuarios.GetUsuariosRed();

return View(Usuarios);

}

//

在我的应用程序中,自定义角色是固定的。

关于asp.net-mvc-4 - 具有自定义角色的 MVC 4 Intranet 身份验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14449499/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com