MVC使用Controller代替Filter完成登錄驗(yàn)證(Session校驗(yàn))學(xué)習(xí)筆記5
之前的學(xué)習(xí)中,在對(duì)Session校驗(yàn)完成登錄驗(yàn)證時(shí),通常使用Filter來(lái)處理,方法類似與前文的錯(cuò)誤日志過(guò)濾,即新建Filter類繼承ActionFilterAttribute類,重寫OnActionExecuting方法,之后直接在需要驗(yàn)證的Action前加上Filter標(biāo)記即可。
1. 新建登陸校驗(yàn)類CheckLoginAttribute
using System.Web.Mvc;
namespace PMS.WebApp.Models
{
public class CheckLoginAttribute:ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
if (filterContext.HttpContext.Session == null || filterContext.HttpContext.Session["user"] == null)
{
filterContext.HttpContext.Response.Redirect("/User/Login");
}
}
}
}
2. 在需要校驗(yàn)的Action增加標(biāo)記以完成校驗(yàn)
using System.Web.Mvc;
using PMS.IBLL;
using PMS.WebApp.Models;
namespace PMS.WebApp.Controllers
{
public class UserController : Controller
{
//
// GET: /User/
//private IUserService _userService;
//private IUserService UserService
//{
// get { return _userService ?? (_userService = new UserService()); }
// set { _userService = value; }
//}
private IUserService UserService { get; set; }
[CheckLogin]
public ActionResult Index()
{
return Content("OK");
}
}
}
注意:不要在RegisterGlobalFilters方法中注冊(cè)校驗(yàn)類,否則則會(huì)相當(dāng)于給所有Action都添加了校驗(yàn)
這種方法使用起來(lái)需要在每個(gè)Action方法前添加過(guò)濾標(biāo)簽,且效率并不十分高,我們的項(xiàng)目中使用的是一種更為簡(jiǎn)單高效的方法:使用Controller進(jìn)行登錄驗(yàn)證
1. 新建一個(gè)用于驗(yàn)證的Controller父類,并在其內(nèi)重寫OnActionExecuting方法完成登陸校驗(yàn):
using System.Web.Mvc;
namespace PMS.WebApp.Controllers
{
public class FilterController : Controller
{
protected override void OnActionExecuting(ActionExecutingContext filterContext)
{
base.OnActionExecuting(filterContext);
if (Session["user"] == null)
{
//filterContext.HttpContext.Response.Redirect("/User/Login");
filterContext.Result = Redirect("/User/Login");
}
}
}
}
在Controller校驗(yàn)類的OnActionExecuting方法中,有如下代碼
//filterContext.HttpContext.Response.Redirect("/User/Login");
filterContext.Result = Redirect("/User/Login");
我們使用后者而放棄前者的原因是,ASP.NET MVC中規(guī)定,Action必須返回ActionResult,如果使用前者,在完成跳轉(zhuǎn)前會(huì)先進(jìn)入到請(qǐng)求的頁(yè)面,這樣不符合我們使用過(guò)濾器的初衷。
2. 然后使需要校驗(yàn)的Controller繼承于我們定義的校驗(yàn)Controller即可完成全局登錄校驗(yàn)操作:
using System.Web.Mvc;
using PMS.IBLL;
namespace PMS.WebApp.Controllers
{
public class UserController : FilterController//Controller
{
//
// GET: /User/
//private IUserService _userService;
//private IUserService UserService
//{
// get { return _userService ?? (_userService = new UserService()); }
// set { _userService = value; }
//}
private IUserService UserService { get; set; }
//[CheckLogin]
public ActionResult Index()
{
return Content("OK");
}
}
}
下面我們對(duì)比兩種方法的優(yōu)缺點(diǎn)
Filter定義過(guò)程比較復(fù)雜,效率也稍低些,但是卻可以對(duì)每一個(gè)Action進(jìn)行單獨(dú)的過(guò)濾,同一Action也可以有多條過(guò)濾信息,使用比較靈活。
Controller定義更為簡(jiǎn)便,效率高,但是卻只能對(duì)整個(gè)Controller中所有方法進(jìn)行過(guò)濾,同一Controller也不太容易有多個(gè)Controller過(guò)濾父類。
綜上所述,實(shí)際項(xiàng)目中大多需求都是同一Controller下所有方法都需要完成登陸驗(yàn)證,所以其實(shí)使用Controller過(guò)濾更為高效,應(yīng)對(duì)復(fù)雜需求時(shí),靈活混用兩種方法也不失為一種好的策略。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
在.ashx文件中獲取cookies值實(shí)現(xiàn)代碼
.ashx文件中獲取cookies值對(duì)于一些高手們就不多說(shuō)了,至于一些小白們還是有必要多多學(xué)習(xí)啊,好了話不多說(shuō),看代碼,感興趣的你可不要錯(cuò)過(guò)了哈2013-02-02
Global.asax的Application_BeginRequest實(shí)現(xiàn)url重寫無(wú)后綴的代碼
本文為大家詳細(xì)介紹下利用Global.asax的Application_BeginRequest 實(shí)現(xiàn)url重寫其無(wú)后綴,具體核心代碼如下,有需求的朋友可以參考下,希望對(duì)大家有所幫助2013-08-08
asp.net 防止用戶通過(guò)后退按鈕重復(fù)提交表單
經(jīng)過(guò)一番仔細(xì)的尋尋覓覓之后,我發(fā)現(xiàn)仍舊無(wú)法找出真正能夠完全禁用瀏覽器后退按鈕的辦法。所有這里介紹的方法都能夠在不同程度上、以不同的方式禁止用戶返回前一頁(yè)面,但它們都有各自的局限。2009-11-11
ASP.NET 2.0 中的創(chuàng)建母版頁(yè)
ASP.NET 2.0 中的創(chuàng)建母版頁(yè)...2006-09-09
c# static 靜態(tài)數(shù)據(jù)成員
靜態(tài)成員屬于類所有,為各個(gè)類的實(shí)例所公用,無(wú)論類創(chuàng)建了幾多實(shí)例,類的靜態(tài)成員在內(nèi)存中只占同一塊區(qū)域。2009-06-06
.NET 9 中 LINQ 新增功能實(shí)現(xiàn)過(guò)程
文章介紹了.NET 9中LINQ新增功能,包括CountBy、AggregateBy和Index方法,并提供了相關(guān)代碼示例和輸出結(jié)果,感興趣的朋友跟隨小編一起看看吧2024-11-11
ASP.NET 6種常用數(shù)據(jù)庫(kù)的連接方法
有Access,SQL Server,Oracle,MySQL,IBM DB2 ,SyBase 等6種數(shù)據(jù)庫(kù)的連接方法,有需要的朋友請(qǐng)往下看2013-03-03
一個(gè).net 壓縮位圖至JPEG的實(shí)例代碼
這篇文章介紹了.net 壓縮位圖至JPEG的實(shí)例代碼,有需要的朋友可以參考一下2013-11-11

