查看Authorize Attribute,您可以将其放在整个控制器上或仅放在控制器中的特定方法上。
例子:
[Authorize(Roles = "Administrator")]
public class AdminController : Controller
{
 //your code here
}
或者
public class AdminController : Controller
{
    //Available to everyone
    public ActionResult Index()
    {
        return View();
    }
    //Just available to users in the Administrator role.
    [Authorize(Roles = "Administrator")]
    public ActionResult AdminOnlyIndex()
    {
        return View();
    }
}
或者,您可以编写自定义 Authorize 属性来提供您自己的逻辑。
public class CustomAuthorizeAttribute : AuthorizeAttribute 
{           
    protected override bool AuthorizeCore(HttpContextBase httpContext)     
    {
        IPrincipal user = httpContext.User;     
        var validRoles = Roles.Split(',');//Roles will be a parameter when you use the Attribute        
        List<String> userRoles = GetRolesFromDb(user);//This will be a call to your database to get the roles the user is in.
        return validRoles.Intersect(userRoles).Any();
    }
} 
要使用:
 [CustomAuthorizeAttribute(Roles = "Admin,Superuser")] 
 public class AdminController : Controller {
 }