好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法

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

熱門標簽:濮陽外呼電銷系統怎么樣 塔城代理外呼系統 地圖定位圖標標注 代理接電話機器人如何取消 400電話辦理哪家性價比高 地圖標注的公司有哪些 天心智能電銷機器人 地圖標注專業團隊 遂寧市地圖標注app

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

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

下面請看步驟:

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

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

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

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("", "lt").Replace(">", "gt");
      if (!string.IsNullOrEmpty(t.TSite))
        t.TSite = t.TSite.Replace("", "lt").Replace(">", "gt");
    }
  }
}

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

public ActionResult Index(TestModel t)
{
     ViewData["ConvertedModel"] = t;
     return View();
}

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

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

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

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

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

[ValidateInput(false)]
[FilterChars]
public ActionResult Index(TestModel t)
{
   ViewData["ConvertedModel"] = t;
   return View();
}

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

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

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

您可能感興趣的文章:
  • 詳解.Net Core 權限驗證與授權(AuthorizeFilter、ActionFilterAttribute)
  • ASP.NET MVC使用ActionFilterAttribute實現權限限制的方法(附demo源碼下載)
  • .NET獲取枚舉DescriptionAttribute描述信息性能改進的多種方法
  • 關于.NET Attribute在數據校驗中的應用教程

標簽:河南 汕頭 婁底 吉林 本溪 麗江 宜春 重慶

巨人網絡通訊聲明:本文標題《asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法》,本文關鍵詞  asp.net,MVC,利用,ActionFilterAttribute,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法》相關的同類信息!
  • 本頁收集關于asp.net MVC利用ActionFilterAttribute過濾關鍵字的方法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 国内精品第一页| 小尤奈裸露双奶头屁股无遮挡,| 碰91精品国产91久久婷婷| 男主疯狂C女二H| 办公室床震揉胸罩视频| 国产精品变态重口在线| 职中美女疯狂?喷水在线观看| 337p亚洲日本欧洲大胆| 男女一边摸一边做爽爽的直播视频| 广南县| 青青青青久久精品国产一百度| 懂色一区二区三区在线播放| 男人j进女人p一进一出视频| 日本特黄a级120秒试看| 微山县| 久久久久久精品无码嘿嘿嘿嘿| 王者荣耀之白丝玉足榨精| 男女性高爱潮在线观看| dorcelclub贵妇系列free| 妻子6免费观看完整版电视剧| 在线观看免费视频当家主母| 日本在线免费观看视频| 日本在线看片| 十九岁在线观看免费完整版国语版| 欧美性极品高清| 被窝电影午夜伦电影| 老师洗澡让我进去摸她乳| 黄色高清网站| 精品久久久无码中文字幕vr| 亚洲综合另类| 蜜桃秘?无码一区二区三区| 337p色噜噜| 97在线视频| 怮交小U女天堂HD| 5544444亚洲成Av人片| 黄色三级日韩| 一级特黄大片 录像i| 戒爱在线观看完整版高清| 丝雅丝袜无内福利视频| 91香蕉视频app污| 久久久精品综合|