欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Asp.net web.config customErrors 如何設(shè)置

 更新時間:2018年02月13日 11:03:30   作者:wolfy  
這篇文章主要介紹了詳解Asp.net web.config customErrors 如何設(shè)置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

摘要

customErrors也經(jīng)常在開發(fā)部署中看到<customErrors mode="Off" />,設(shè)置這樣可以在頁面上看到詳細的錯誤信息。但也為黑客提供了攻擊的線索。

customErrors

該節(jié)點有三種可選的設(shè)置項

  1. On:服務(wù)器開發(fā)的最安全選項,因為它總是隱藏錯誤提示信息。
  2. RemoteOnly:向大多數(shù)用戶展示一般的錯誤信息,但向擁有服務(wù)器訪問權(quán)限的用戶展示完整的錯誤提示信息。換句話說,僅向遠程客戶端端顯示自定義錯誤,并向本地主機顯示 ASP.NET 錯誤。默認值。
  3. Off:最容易受到攻擊的選項,它向訪問網(wǎng)站的每個用戶展示詳細的錯誤提示消息。

詳細的錯誤信息可能會暴露應(yīng)用程序的內(nèi)部結(jié)構(gòu),比如如果寫的sql語句中報錯,可能會暴露數(shù)據(jù)表,以及sql語句,這是非常不安全的。在Off設(shè)置下的網(wǎng)站,黑客會不斷的嘗試,傳遞不同的參數(shù),使你的網(wǎng)站出錯,然后暴露你的應(yīng)用程序的內(nèi)部結(jié)構(gòu)。

mode=Off

比如:

<system.web>
  <authentication mode="None" />
  <compilation debug="true" targetFramework="4.5" />
  <httpRuntime targetFramework="4.5" />
  <customErrors mode="Off" defaultRedirect="error">
  </customErrors>
 </system.web>

在TestAction中直接拋出一個異常,那么我們可以看到與下面類似的黃頁

在黃頁上面可以看到,頁面對應(yīng)邏輯的堆棧信息,進而暴露項目結(jié)構(gòu)信息。非常的不安全。

那么如果是mode=Off,并且在事件Application_Error中記錄并清除錯誤,會看到什么結(jié)果?

 protected void Application_Error(object sender, EventArgs e)
    {
      var context = HttpContext.Current;
      if (context != null)
      {

        Exception objErr = context.Server.GetLastError();
        if (objErr != null)
        {
          string err = "Error Caught in Application_Error event/n" + "Error in:" 
+ Request.Url.ToString() + "/nError Message:" + objErr.Message.ToString() +
       "/nStack Trace:" + objErr.StackTrace.ToString();
        、、、、、日志邏輯
          Server.ClearError(); 
        }
      }
    }
 <customErrors mode="Off" defaultRedirect="Error">   
 </customErrors>

defaultRedirect 指定發(fā)生錯誤時瀏覽器指向的默認 URL。如果沒有指定 defaultRedirect,則會顯示一般性錯誤。URL 既可以是絕對的(例如 http://www.***.com/ErrorPage.htm),也可以是相對的。相對 URL(如 /ErrorPage.htm)是相對于指定 defaultRedirect 的 Web.config 文件而言的,而不是針對產(chǎn)生錯誤的網(wǎng)頁。以波形符 (~) 開頭的 URL(如 ~/ErrorPage.htm)表示所指定的 URL 是相對于應(yīng)用程序根路徑而言的。

通過上面的操作,如果設(shè)置Off,并且在Application_Error事件中捕獲異常,并 Server.ClearError(),那么如果報錯,在前端頁面就會看到空白的頁面。

通過這個也可以說明,如果應(yīng)用程序出錯,先觸發(fā)的Application_Error事件,ClearError之后,那么在頁面上就看不到結(jié)果了。

mode=On

在設(shè)置On模式情況下,如果應(yīng)用程序發(fā)生錯誤,會跳轉(zhuǎn)到自定義的錯誤頁,這里使用了defaultRedirect屬性,并沒有配置 <error statusCode="500" redirect="error"/>

mode=RemoteOnly

通過字面意思,僅僅遠程,僅僅遠程什么呢?可以看下例子。目前所在編碼環(huán)境,通過vs調(diào)試狀態(tài),相對遠程要訪問的用戶,可以將本機當做服務(wù)器。那么這就是本地,遠程訪問的瀏覽器就是Remote。

可以看到,在服務(wù)器端,訪問仍然能看到黃頁,也就是上面所說的ASP.NET錯誤。那么我們將站點部署在服務(wù)器,然后在本地訪問會出現(xiàn)什么情況呢?

通過客戶端訪問服務(wù)器的url,則會跳轉(zhuǎn)到默認的自定義錯誤頁面。那么在服務(wù)器端又是什么情況呢?

說明: 僅向遠程客戶端端顯示自定義錯誤,并向本地主機顯示 ASP.NET 錯誤

 總結(jié)

所以,不要在生產(chǎn)環(huán)境中將customErrors關(guān)閉。 推薦開啟RemoteOnly或者On并定義自定義的錯誤頁面。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • ASP.NET?Core使用AutoMapper組件

    ASP.NET?Core使用AutoMapper組件

    這篇文章介紹了ASP.NET?Core使用AutoMapper組件的方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • ASP.NET MVC Admin主頁快速構(gòu)建

    ASP.NET MVC Admin主頁快速構(gòu)建

    這篇文章主要為大家詳細介紹了ASP.NET MVC Admin主頁快速構(gòu)建的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • asp.net Repeater 自增

    asp.net Repeater 自增

    asp.net Repeater 自增加實現(xiàn)代碼。
    2009-06-06
  • .NET關(guān)于API 句柄泄漏分析

    .NET關(guān)于API 句柄泄漏分析

    本文主要介紹了.NET關(guān)于API 句柄泄漏分析,文中結(jié)合代碼與圖片講解的非常詳細,感興趣的小伙伴可以自行參考一下
    2021-08-08
  • ASP.NET使用xslt將xml轉(zhuǎn)換成Excel

    ASP.NET使用xslt將xml轉(zhuǎn)換成Excel

    本文介紹利用Excel軟件生成格式,提取和精簡之后制作成xslt文件,將xml導(dǎo)入,以xslt為模板,生成新的Excel文件的過程。
    2016-05-05
  • Aspx/Asp.net 防注入程序 V1.0

    Aspx/Asp.net 防注入程序 V1.0

    asp下有人寫了防注入的程序,這次看到了一個asp.net的特提供給大家參考。
    2009-10-10
  • Asp.net回調(diào)技術(shù)Callback學(xué)習筆記

    Asp.net回調(diào)技術(shù)Callback學(xué)習筆記

    這篇文章主要記錄了Asp.net回調(diào)技術(shù)Callback的一些知識,感興趣的朋友可以參考下
    2014-08-08
  • 超好用輕量級MVC分頁控件JPager.Net

    超好用輕量級MVC分頁控件JPager.Net

    本文給大家分享的是一款超好用輕量級MVC分頁控件--JPager.Net,小編自己也在使用,非常的不錯,推薦給大家。
    2016-06-06
  • .NET邏輯分層架構(gòu)總結(jié)

    .NET邏輯分層架構(gòu)總結(jié)

    本人將從另一個角度來解析.NET分層架構(gòu)的真正奧秘。分層,一些技術(shù)功底比較薄弱的程序員聽到分層就會聯(lián)想到三層架構(gòu)(BLL,DAL之類的),其實不是,分層是一個很大的技術(shù)框架思想,三層架構(gòu)只不過是對普通的信息系統(tǒng)來說,將信息的流轉(zhuǎn)通過三層來分解,
    2015-06-06
  • IIS中ASP.NET連接SQL Server出錯的解決方法

    IIS中ASP.NET連接SQL Server出錯的解決方法

    在IIS中運行的ASP.NET應(yīng)用程序其所屬用戶名為ASPNET的特定用戶,其默認權(quán)限是無法訪問SQL Server的,更不可能訪問ASP.NET應(yīng)用程序的數(shù)據(jù)庫了,因此要在IIS中訪問SQL Server就需要給ASPNET帳戶賦予相應(yīng)的權(quán)限.
    2010-03-03

最新評論