asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法
來源:易賢網(wǎng) 閱讀:890 次 日期:2016-08-10 15:34:29
溫馨提示:易賢網(wǎng)小編為您整理了“asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法”,方便廣大網(wǎng)友查閱!

本文實(shí)例講述了asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法。分享給大家供大家參考,具體如下:

在開發(fā)過程中,有時候會對用戶輸入進(jìn)行過濾,以便保證平臺的安全性。屏蔽的方法有很多種,但是今天我說的這種主要是利用MVC中的ActionFilterAttribute屬性來實(shí)現(xiàn)。由于MVC天然支持AOP,所以我們這種過濾方式正好利用了MVC的這種特性。

下面請看步驟:

首先,當(dāng)用戶輸入自己的名稱的時候,帶有類似<BR>的內(nèi)容的時候,由于MVC默認(rèn)是需要驗(yàn)證內(nèi)容的,所以,會拋出一張黃頁錯誤,提示用戶:從客戶端檢測到潛在風(fēng)險的Request值。這種頁面是極為不友好的,同時也是我們作為開發(fā)最不想見到的頁面,屏蔽這個錯誤很簡單,就是在響應(yīng)的頁面ActionResult上面加上[ValidateInput(false)]的特性,這樣當(dāng)用戶提交的時候,頁面將不會再次對輸入內(nèi)容做檢測。

如果容忍這樣的行為,將會對系統(tǒng)的安全性造成威脅,所以最好的解決方法就是講其中類似 <>等進(jìn)行轉(zhuǎn)義。

下面我們就來利用ActionFilterAttribute構(gòu)造自己的轉(zhuǎn)義過濾類:

using System.Web.Mvc;

using TinyFrame.Plugin.StrongTyped.Models;

namespace TinyFrame.Plugin.StrongTyped

{

  public class FilterCharsAttribute : ActionFilterAttribute

  {

    protected string parameterName = "t";

    protected TestModel model;

 public override void OnActionExecuting(ActionExecutingContext filterContext)

    {

      base.OnActionExecuting(filterContext);

   //No Parameters, will return directly.

      if(!filterContext.ActionParameters.ContainsKey(parameterName))

        return;

   var t = filterContext.ActionParameters[parameterName] as TestModel;

   //No Entity data, will return directly

      if (t == null)

        return;

   //Replace chars that should be filtered

      if (!string.IsNullOrEmpty(t.TName))

        t.TName = t.TName.Replace("<", "<").Replace(">", ">");

      if (!string.IsNullOrEmpty(t.TSite))

        t.TSite = t.TSite.Replace("<", "<").Replace(">", ">");

    }

  }

}

第8行,代表我們的用戶輸入的實(shí)體類參數(shù),具體的Controller代碼如下:

public ActionResult Index(TestModel t)

{

     ViewData["ConvertedModel"] = t;

     return View();

}

第11行,通過重載OnActionExecuting方法,我們可以定義自己的Filter。

第19行,將獲取的Input結(jié)果轉(zhuǎn)換成entity。

第27,29行,將潛在的危險字符進(jìn)行轉(zhuǎn)義。

這樣書寫完畢之后,我們就打造了一個可以過濾掉關(guān)鍵字的Filter了。如果想要做的通用的話,需要對輸入的filterContext.ActionParameters進(jìn)行遍歷,并通過反射構(gòu)建實(shí)例,再通過反射字段值,實(shí)現(xiàn)通用的關(guān)鍵字過濾。這里我只提供思路,具體的做法就看自己了。

然后將這個方法加入到Controller中需要檢測的頁面的頭部,即可:

[ValidateInput(false)]

[FilterChars]

public ActionResult Index(TestModel t)

{

   ViewData["ConvertedModel"] = t;

   return View();

}

這樣,我們就完成了對輸入數(shù)據(jù)的過濾操作,下面看看結(jié)果吧:

名單

我們可以清楚的看到,輸入結(jié)果,輸出后,一對尖角號被轉(zhuǎn)義了。

希望本文所述對大家asp.net程序設(shè)計(jì)有所幫助。

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:asp.net MVC利用ActionFilterAttribute過濾關(guān)鍵字的方法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報警專用圖標(biāo)