Zaa*_*aak 10 asp.net-mvc controller asp.net-membership session-variables asp.net-mvc-3
我有控制器的覆盖,检查是否存在某些会话数据.存储库正常工作需要此数据,因此如果它不存在,则在检查之后应该注销用户.
protected override void Initialize(System.Web.Routing.RequestContext requestContext)
{
base.Initialize(requestContext);
if (Session["CompanyID"] != null)
{
repo.CompanyID = (long)Session["CompanyID"];
}
else
{
RedirectToAction("LogOff", "Account");
}
}
Run Code Online (Sandbox Code Playgroud)
我的代码看起来像这样,但即使调用RedirectToAction,控制器仍会打开默认操作,用户也不会注销.你能推荐一下如何处理这个问题吗?
我正在以这种方式使用这个会话数据,因为这是我知道的第一个地方,在这里我可以检查这个特定的数据是否存在.它是在用户登录时写入的.
此数据是数据库中User的一部分.我已经成为自定义成员资格和角色提供者.有没有办法将这些数据以某种方式添加到MembershipUser类型的"User"中,以便可以在构造函数中访问用户用户名?
Ric*_*lly 14
请考虑使用自定义ActionFilter.
public class HasCompanyIdAttribute : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
if (filterContext.HttpContext.Session["CompanyID"] == null)
{
filterContext.Result = new RedirectToRouteResult(new RouteValueDictionary(new {action = "LogOff", controller = "Account"}));
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后可以这样应用:
[HasCompanyId]
public class MyController : Controller
{
public ActionResult SomeAction()
{
return View();
}
}
Run Code Online (Sandbox Code Playgroud)
这将为MyController(或它的子类)处理的所有请求应用该属性.
| 归档时间: |
|
| 查看次数: |
8007 次 |
| 最近记录: |