ASP MVC中的视图中的权限

qui*_*qui 4 permissions asp.net-mvc user-interface

我了解您可以使用表单身份验证根据您选择的条件授予/拒绝对某些页面的访问权限.

但是我希望比这更具体一点,并且说,根据用户的权限为用户显示不同的按钮.

我知道我可以做点什么

if(((User)ViewData["CurrentUser"]).IsEmployee).....
Run Code Online (Sandbox Code Playgroud)

但这似乎并不优雅,很快就会变得混乱.

是否有任何指南/工具/框架功能可以帮助我在这里?

Cra*_*ntz 6

使用基于角色的身份验证,然后适当地设置角色.然后你可以做以下事情:

if (ViewContext.HttpContext.User.IsInRole("vEmployee") {
Run Code Online (Sandbox Code Playgroud)

这样做的好处在于它是ASP.NET的核心功能 - 甚至不是特定于MVC的 - 因此它可以与每个可能的成员资格提供者一起使用.

然后,您可以为要有条件地显示的任何控件添加视图助手重载:

public static string TextBox(this HtmlHelper helper, 
    string name, string value, string role, object htmlAttributes)
{
   if helper.ViewContext.HttpContext.User.IsInRole(role) {
       return helper.TextBox(name, value, htmlAttributes);
   } 
   else
   {
       return null;
   }
}
Run Code Online (Sandbox Code Playgroud)

......并称之为:

<%= Html.TextBox("name", "value", "vEmployee", null) %>
Run Code Online (Sandbox Code Playgroud)