激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - ASP.NET教程 - asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法

asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法

2020-01-02 13:47程序詩人 ASP.NET教程

這篇文章主要介紹了asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法,結合實例形式分析了ActionFilterAttribute過濾關鍵字的原理與相關實現技巧,需要的朋友可以參考下

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

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

下面請看步驟:

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

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

下面我們就來利用ActionFilterAttribute構造自己的轉義過濾類:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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行,代表我們的用戶輸入的實體類參數,具體的Controller代碼如下:

?
1
2
3
4
5
public ActionResult Index(TestModel t)
{
     ViewData["ConvertedModel"] = t;
     return View();
}

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

第19行,將獲取的Input結果轉換成entity。

第27,29行,將潛在的危險字符進行轉義。

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

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

?
1
2
3
4
5
6
7
[ValidateInput(false)]
[FilterChars]
public ActionResult Index(TestModel t)
{
   ViewData["ConvertedModel"] = t;
   return View();
}

這樣,我們就完成了對輸入數據的過濾操作,下面看看結果吧:

asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法

我們可以清楚的看到,輸入結果,輸出后,一對尖角號被轉義了。

希望本文所述對大家asp.net程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品亚洲欧美日韩精品中文字幕 | 国产成年人视频网站 | 国产精品久久久久久久久久尿 | 国产美女爽到喷白浆的 | 不卡国产一区二区三区四区 | 亚洲一区二区三区在线 | 狠狠操电影| 精品国产一区二区三 | 特级黄一级播放 | 欧美一级片一区 | 久久国产精品区 | 伊人手机在线观看 | 久久精品久久久久 | 日本一区二区精品视频 | 成人在线免费视频播放 | 九九热色| 久久99精品久久久久久园产越南 | 福利免费在线 | 热@国产 | 黄网站在线免费 | 性大片性大片免费 | 性爱在线免费视频 | 九九热视频这里只有精品 | 欧美成人一区免费视频 | av免费在线观看av | 一区二区三区视频播放 | 91短视频版高清在线观看www | 视频一区二区三区在线观看 | 超碰97国产在线 | 5xsq在线视频 | 草久视频在线观看 | 亚洲精品久久久久久久久久 | 久久午夜神器 | 久久久国产一级片 | 久草在线资源视频 | 超碰97人人艹 | 色屁屁xxxxⅹ在线视频 | 国产成年人视频网站 | 性欧美日本 | 最污网站 | 嫩呦国产一区二区三区av |