ASP.NET MVC應用安全性(一)——自定義錯誤處理

来源:https://www.cnblogs.com/AloneZ/archive/2018/03/09/8532415.html
-Advertisement-
Play Games

很多 ASP.NET MVC 開發者都會寫出高性能的代碼,很好地交付軟體,等等。但是卻並沒有安全性方面的計劃。 有一種攻擊是攻擊者截獲最終用戶提交的表單數據,將其改變再將修改後的數據發送到伺服器。 對於這種情況,開發者需要進行適當的驗證,不過驗證顯示的大量錯誤信息中可能會泄漏伺服器信息。 如常見的4 ...


很多 ASP.NET  MVC 開發者都會寫出高性能的代碼,很好地交付軟體,等等。但是卻並沒有安全性方面的計劃。

有一種攻擊是攻擊者截獲最終用戶提交的表單數據,將其改變再將修改後的數據發送到伺服器。

對於這種情況,開發者需要進行適當的驗證,不過驗證顯示的大量錯誤信息中可能會泄漏伺服器信息。

如常見的404頁面和500頁面(俗稱黃頁):

         


 

解決方法:

  • 先關閉自定義錯誤,將Web.config配置文件中customErrors節點的mode設置為Off
1 <system.web>
2     <customErrors mode="Off"></customErrors>
3     <compilation debug="true" targetFramework="4.5"/>
4     <httpRuntime targetFramework="4.5"/>
5   </system.web>
  • 在GlobalFilter全局過濾器中取消HandleErrorAttribute的註冊
1     public class FilterConfig
2     {
3         public static void RegisterGlobalFilters(GlobalFilterCollection filters)
4         {
5             //filters.Add(new HandleErrorAttribute());
6         }
7 
8     }
  • Global.asax文件並添加Application_Error事件代碼
 1         protected void Application_Error(Object sender, EventArgs e)
 2         {
 3             Exception exception = Server.GetLastError();
 4             if (exception != null)
 5             {
 6                 HttpException httpException = exception as HttpException;
 7                 if (httpException != null)
 8                 {
 9                     int errorCode = httpException.GetHttpCode();
10                     if (errorCode == 400 || errorCode == 404)
11                     {
12                         Response.StatusCode = 404;
13                         Response.Redirect(string.Format("~/Error/Error404"), true);
14                         Server.ClearError();
15                         return;
16                     }
17                 }
18 
19                 var postData = string.Empty;
20                 try
21                 {
22                     using (System.IO.Stream stream = Request.InputStream)
23                     {
24                         using (System.IO.StreamReader streamReader = new System.IO.StreamReader(stream, System.Text.Encoding.UTF8))
25                         {
26                             postData = streamReader.ReadToEnd();
27                         }
28                     }
29                 }
30                 catch { }
31 
32                 //該方法為寫錯誤日誌和發送錯誤郵件給開發者的方法(可忽略)
33                 LogCache.Instance.saveToLog(Request, AppDomain.CurrentDomain.BaseDirectory + @"\privateFolder\SysLog\Error\", DateTime.Now.ToString("yyyyMMddHH") + ".log", postData, exception.ToString());
34 
35                 Response.StatusCode = 500;
36                 Response.Redirect(string.Format("~/Error/Error500"), true);
37                 Server.ClearError();
38             }
39         }
  • 添加自定義的404、500頁面

 

最終實現效果:

        

 

使用應用程式全局錯誤的一些優勢:

第一點就是相容性好,Web Form和MVC中都可以通用,如果舊的Web Form項目中是使用Application_Error處理全局異常,那麼在新的MVC項目就可以很容易移植過來!此外靈活性也比較高,相比ASP.NET自帶的自定義錯誤以及MVC的HandleError特性,可以更加自由的編寫靈活的業務代碼。

另外可以根據需求設定HTTP錯誤碼,這方面也是考慮到一個SEO的問題,畢竟ASP.NET的自定義錯誤機智是使用302重寫跳轉,並不有利於SEO。雖然customErrors節點的redirectMode屬性可以設置為"ResponseRewrite"(重寫),但是如果在跳轉的頁面上不設置HTTP錯誤碼,則HTTP狀態碼為200。

Application_Error處理網站異常的局限性:

Application_Error事件無法處理已經被處理的異常,比如在try-catch捕捉的異常。此外由於是應用程式級別的事件,所以無法處理操作方法或者控制器級別的異常,暫時我也只想到這些局限,一般來說只要項目沒有什麼特殊要求都可以使用此事件處理自定義異常。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 貼一個EF6 CodeFirst模式結合MVC5和Autofac(泛型註冊)的一個入門實例 網上類似的例子實在太少,最近自己也有用到這一塊的知識,總結了一下,不要讓後人踩了自己踩過的坑。 1:新建三個項目,Web(MVC)、EntityFramework類庫(EF框架)、Core類庫(核心框架),n ...
  • 1. 生活中0.1+0.2=0.3, 電腦中可不是這樣,為什麼呢? 大家都知道電腦類型都是有數據範圍的。整形int範圍是 正負21億左右,小數類型同樣也是有範圍的,但是即使0.1~0.2之前如果問你有多少小數? 無窮個!!! 那麼有限的範圍怎麼表示無限的數據呢? 告訴你表示不了,只能存儲一個無限 ...
  • 1.Action、RenderAction載入辦法的視圖,履行Controller → Model → View的次序,然後把產生的頁面帶回到本來的View中再回傳。而Partial、RenderPartial直接載入視圖文件內容 2.Html.Partial可以直接供給用戶控制項名作為參數,而Htm ...
  • Html.BeginForm Add:操作方法的名稱,Activities:控制器的名稱,FormMethod.Post:定義from的method的值,,new { id = "form1"}:指定form的id 後臺 接收 submit 提交; [HttpPost] public ActionR ...
  • 在開發中經常經常碰到標誌多選的情況,如將listbox的選擇結果保存到資料庫,最好的方式就是將每個選項用一個二進位標誌,實現每個標誌為1,則只需要將每個選擇的選項結果累加就可以保存到資料庫。 可封裝如下 ...
  • 在C 語言中,要使類型對象可以排序,可以基於介面實現,主要的介面有IComparable\、IComparer\,當然我們還可以通過強大的LINQ進行排序。 IComparable\介面 ================= IComparable\定義由值類型或類實現的通用比較方法,以為排序實例創建 ...
  • 這次學習ng-selected語法,這個是為DropDownList下拉列表顯示預設選項。 演示從下麵步驟開始 1,新建一個model: 上面#14行代碼的property,數據類型為bool。即是存儲選項是否為選中與否,true或false。 public class Car { public i ...
  • 目錄: ASP.NET Core 2.0: 二. 開發環境 ASP.NET Core 2.0 : 三. 項目結構 ASP.NET Core 2.0 : 四. _Layout與_ViewStart ASP.NET Core 2.0 : 五.服務是如何載入並運行的, Kestrel、配置與環境 ASP. ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...