asp.net-mvc – MVC4区域和表单认证
发布时间:2020-10-19 17:28:47 所属栏目:asp.Net 来源:互联网
导读:我有一个MVC4应用程序设置了多个领域.每个区域都必须有自己的登录页面.比方说我有以下几个方面: 主要 管理员 如何设置它,使“主”区域有不同的登录页面到“管理”区域?我认为web.config不是这样的方式. 目前我的根web.config文件中有以下内容: authenticat
|
我有一个MVC4应用程序设置了多个领域.每个区域都必须有自己的登录页面.比方说我有以下几个方面: 主要 如何设置它,使“主”区域有不同的登录页面到“管理”区域?我认为web.config不是这样的方式. 目前我的根web.config文件中有以下内容: <authentication mode="Forms"> <forms loginUrl="~/Admin/Login" timeout="2880" protection="Encryption" /> </authentication> 但是,我正在努力解决如何适应这个MVC4与区域. 请帮忙. 解决方法我不知道是否可以使每个文件夹中的配置文件起作用.如果可以,请使用该解决方案.如果您不能,则可以使用自定义操作过滤器:public class AreaAuthorizeAttribute : System.Web.Mvc.AuthorizeAttribute
{
protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)
{
string area = filterContext.RouteData.Values.ContainsKey("area")
? filterContext.RouteData.Values["area"].ToString()
: null;
if (area == "Admin")
{
RouteValueDictionary routeValues = new RouteValueDictionary
{
{"controller","Login"},{"action","Index"},{"area","Admin"}
};
filterContext.Result = new RedirectToRouteResult("AdminAreaRoute",routeValues);
}
else if (area == "User")
{
RouteValueDictionary routeValues = new RouteValueDictionary
{
{"controller","User"}
};
filterContext.Result = new RedirectToRouteResult("UserAreaRoute",routeValues);
}
base.HandleUnauthorizedRequest(filterContext);
}
}
您可能需要修复路由名称,我不记得如果ASP.NET MVC生成每个区域的路由.那么你可以这样使用它: [AreaAuthorize]
public ViewResult Index()
{
return View("Index");
} (编辑:鄂州站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- 在ASP.NET中实现多文件上传的方法
- asp.net-core – 编译netcoreapp1.0,代码包含#if!NETSTAND
- asp.net – 如何从WCF客户端拦截raw soap request / respon
- ASP.NET Webdeploy失败;项目中不存在AddScheduledJob
- ASP.NET异步方法问题
- 如何从经典ASP输出Excel * .xls文件
- 实体框架 – WebApi OData:$filter’any’或’all’查询不
- asp.net-mvc – 使用Entity FrameWork保存更改/更新数据集中
- asp.net-mvc – 使用ASP.NET MVC进行项目组织的最佳实践
- asp.net – 如何使用Inno Setup脚本创建IIS应用程序和应用程
