亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

MVC使用 Elmah 日志記錄組件

2019-11-17 02:09:35
字體:
來源:轉載
供稿:網友

MVC使用 Elmah 日志記錄組件

2015-06-12 16:10 by jiangys, ... 閱讀, ... 評論, 收藏, 編輯

簡介

ELMAH(ErrorLoggingModulesandHandlers)錯誤日志記錄模塊和處理程序,是一種應用廣泛的錯誤日志工具是完全可插拔。它可以動態添加到一個正在運行的asp.netWeb應用程序,甚至是一臺機器上的所有ASP.NETWeb應用程序,而無需重新編譯或重新部署。

ELMAH既支持ASP.NETWebForms又支持ASP.NETMVC。你可以對ELMAH進行配置來存儲各種不同的錯誤(xml文件,事件日志,access數據庫,SQL數據庫,Oracle數據庫,或者計算機RAM。)你還可以讓ELMAH在錯誤發生的時候,把錯誤信息email給你。

在默認情況下,在一個已經安裝ELMAH的網站中,你可以通過請求的elmah.axd頁面的方式來訪問ELMAH。

使用方法

本篇來嘗試Elmah在Asp.netMVC 5使用.

第一步:安裝布署

首先Build空的Asp.netMVC 5 PRoject:

添加Elmah引用:

Elmah組建已經配置成功.其實這個過程做了兩件事:

  • A:將Elmah.dll復制到程序的根目錄的Bin文件夾下.并當前項目的引用.
  • B:向項目根目錄下Web.Config文件添加如下內容

在webConfig文件中添加如下內容:

  <configSections>    <sectionGroup name="elmah">      <section name="security" requirePermission="false" type="Elmah.SecuritySectionHandler, Elmah" />      <section name="errorLog" requirePermission="false" type="Elmah.ErrorLogSectionHandler, Elmah" />      <section name="errorMail" requirePermission="false" type="Elmah.ErrorMailSectionHandler, Elmah" />      <section name="errorFilter" requirePermission="false" type="Elmah.ErrorFilterSectionHandler, Elmah" />    </sectionGroup>  </configSections><elmah>    <!--        See http://code.google.com/p/elmah/wiki/SecuringErrorLogPages for         more information on remote access and securing ELMAH.    -->    <security allowRemoteAccess="false" />  </elmah>  <location path="elmah.axd" inheritInChildapplications="false">    <system.web>      <httpHandlers>        <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />      </httpHandlers>      <!--         See http://code.google.com/p/elmah/wiki/SecuringErrorLogPages for         more information on using ASP.NET authorization securing ELMAH.      <authorization>        <allow roles="admin" />        <deny users="*" />        </authorization>      -->    </system.web>    <system.webServer>      <handlers>        <add name="ELMAH" verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" preCondition="integratedMode" />      </handlers>    </system.webServer>  </location>

第二步:測試使用

HomeController.cs

using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.Mvc;namespace Elmah.Demo.Controllers{    public class HomeController : Controller    {        //        // GET: /Home/        public ActionResult Index()        {            return View();        }        [HttpPost]        public ActionResult GenerateError(string error)        {            throw new ApplicationException(error);        }    }}

index.cshtml

@{    Layout = null;    ViewBag.Title = "Index";}<div>    <input type="text" id="ErrorMsg" />    <button id="GenerateError">生成錯誤日志</button>    <a href="/elmah.axd" target="_blank">在elmah中查看錯誤日志</a></div><script src="~/Scripts/jquery-1.10.2.js"></script><script type="text/javascript">    $("#GenerateError").click(function () {        $.post("/Home/GenerateError?error=" + $("#ErrorMsg").val());    });</script>

運行效果如下:

如果不是Post方式,會報黃頁,如:

來看看Elmah是否記錄本次執行過程中出現的異常:

可以看到Elmah已經如期的撲捉到當前應用程序的異常.ELMAH在后臺記錄了錯誤信息,并為我們提供了查詢錯誤日志信息的界面,只需要簡單的操作,就完成了基本的需求.

存儲方式

有人可能會問,上面的自動配置中,并沒有指定存儲日志的方式?。ó斎贿@里還沒介紹如何配置,但是從上面配置中,似乎也看不到有哪里指定了存儲方 式),那這些數據存儲在哪里了呢?答案是,NuGet安裝ELMAH后,它是沒有指定任何存儲方式。而ELMAH認為,如果沒有指定存儲方式,那么就采用 默認的內存存儲方式(也可以顯式的指定)。但是這種存儲方式只能作為調試階段使用,生產環境下不應使用此方式,具體的缺點請看下面對內存存儲方式的介紹。

接下來就具體介紹各種存儲方式,分別以數據庫存儲、文件存儲和內存存儲為例,需要強調一點,ELMAH目前只支持一下三種方式中的任意一種,不支持同時采用多種記錄方式。(想必也沒這個必要)

1.內存存儲方式

內存存儲,顧名思義,將日志記錄于操作系統分配給應用程序的內存中。應用程序的內存是與應用程序域相關的,這可以保證每個應用程序只能獲取和記錄屬于自己 的日志信息。但是,一旦應用程序重啟,之前記錄的信息將會消失。最簡單的例子,如果你用這種方式調試呢,默認是用ASP.NET Development Server作為web服務器,如果這時停止此服務器,則就滿足上述條件了(如下圖)。另外,斷電,發布后IIS的重啟等問題,都會導致記錄的信息丟失。 因此,這種方式只能用于測試用。

其實Elmah處理原理.當我們請求頁面報錯時.在返回黃頁錯誤時首先被 httpModules中名為ErrorLog模塊進行攔截. 該模塊將本次請求出錯的信息保存起來.-默認是放置在內存中.便于即時調試.但用戶輸入elmah.axd要查看日志信息時. 首先httpHandlers捕獲到該請求.并交給專門處理elmah.axd的處理程序.該模塊把錯誤日志View返回給用戶.可見Elmah核心技術 還是基于HttpModules和HttpHandlers來實現的.

2.文件存儲方式

文件存儲實際上ELMAH提供了xml文件的存儲方式,每一個報錯日志信息生成一個xml文件。配置相當簡單:

  <elmah>    <!--        See http://code.google.com/p/elmah/wiki/SecuringErrorLogPages for         more information on remote access and securing ELMAH.    -->    <security allowRemoteAccess="false" />    <!--只有這一句就行了,其中logPath用于指定記錄日志的文件夾位置-->    <errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="~/Static/Log/" />  </elmah>

該配置必需確認LogPath路徑目錄是完整存在的.測試會發現在本地文件中(/Elmah.Demo/Static/Log)會出現一個XML文件:

3. 數據庫存儲方式

在數據可視化和管理上數據庫依然是最理想的選擇.這里采用SQlServer2008 版本測試.在構建Elmah支持SQLServer數據支持需要如下三個操作:

  • a)告訴ELMAH使用哪種數據庫作為存儲數據庫;
  • b)告訴ELMAH如何連接到數據庫;
  • c)指定的數據庫里,要包含ELMAH需要的表、視圖和存儲過程等(嵌入式數據庫不需要此過程)。

其中a和b步驟需要在web.config中指定,c則需要在數據庫中添加相關對象。

web.config配置如下(httpModules以及httpHandlers就不貼了,這里只給出ELMAH記錄日志于sqlserver數據庫的配置):

  <connectionStrings>    <add name="elmah-sqlserver" connectionString="server=.;database=MvcTest;user id=sa;passWord=111111@a" providerName="System.Data.SqlClient" />  </connectionStrings>  <elmah>    <!--        See http://code.google.com/p/elmah/wiki/SecuringErrorLogPages for         more information on remote access and securing ELMAH.    -->    <security allowRemoteAccess="false" />    <!--只有這一句就行了,其中logPath用于指定記錄日志的文件夾位置-->    <!--<errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="~/Static/Log/" />-->    <!-- 告訴elmah,我要采用sqlserver來記錄我的日志,連接那個數據庫的字符串名為myconnectionString。-->    <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="elmah-sqlserver" />  </elmah>

創建數據庫,在該數據執行如下SQL語句.請參考官方的連接.

Elmah SQL Server Script File:http://code.google.com/p/elmah/source/browse/src/Elmah/SQLServer.sql

腳本:

CREATE TABLE dbo.ELMAH_Error(    ErrorId     UNIQUEIDENTIFIER NOT NULL,    Application NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    Host        NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    Type        NVARCHAR(100) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    Source      NVARCHAR(60) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    Message     NVARCHAR(500) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    [User]      NVARCHAR(50) COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL,    StatusCode  INT NOT NULL,    TimeUtc     DATETIME NOT NULL,    Sequence    INT IDENTITY (1, 1) NOT NULL,    AllXml      NTEXT COLLATE SQL_Latin1_General_CP1_CI_AS NOT NULL ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]GOALTER TABLE dbo.ELMAH_Error WITH NOCHECK ADD     CONSTRAINT PK_ELMAH_Error PRIMARY KEY NONCLUSTERED    (        ErrorId    )  ON [PRIMARY] GOALTER TABLE dbo.ELMAH_Error ADD     CONSTRAINT DF_ELMAH_Error_ErrorId DEFAULT (newid()) FOR [ErrorId]GOCREATE NONCLUSTERED INDEX IX_ELMAH_Error_App_Time_Seq ON dbo.ELMAH_Error(    [Application] ASC,    [TimeUtc] DESC,    [Sequence] DESC) ON [PRIMARY]GOSET QUOTED_IDENTIFIER ON GOSET ANSI_NULLS ON GOCREATE PROCEDURE dbo.ELMAH_GetErrorXml(    @Application NVARCHAR(60),    @ErrorId UNIQUEIDENTIFIER)ASSET NOCOUNT ONSELECT     AllXmlFROM     ELMA
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91高潮在线观看| 国产一区二区美女视频| 亚洲视频在线观看免费| 国产成人av在线| 欧美精品福利在线| 亚洲国产精品人人爽夜夜爽| 91精品国产综合久久男男| 国产精品久久在线观看| 久久视频国产精品免费视频在线| 日韩精品极品在线观看播放免费视频| 91av在线免费观看| 欧美极品少妇xxxxx| 91精品中文在线| 亚洲欧美日韩网| 亚洲欧美第一页| 国产一区私人高清影院| 色妞久久福利网| 成人乱人伦精品视频在线观看| 欧美午夜精品在线| 亚洲成色777777女色窝| 国产精品视频内| 欧美乱大交xxxxx另类电影| 高清一区二区三区四区五区| 欧美精品videos另类日本| 欧美老女人www| 中文字幕亚洲欧美在线| 亚洲欧美中文字幕| 国产深夜精品福利| 欧美精品videossex性护士| 日本精品久久中文字幕佐佐木| 国产欧美日韩精品专区| 91国产高清在线| 日韩电影免费观看在线| 日韩精品日韩在线观看| 午夜精品一区二区三区在线视| 欧美性猛交99久久久久99按摩| 欧美日韩免费看| www.国产一区| 精品亚洲一区二区三区| 亚洲人成网站色ww在线| 亚洲二区在线播放视频| 91精品国产自产在线观看永久| 国产欧洲精品视频| 欧美在线视频网| 日韩精品视频在线观看网址| 亚洲色在线视频| 日韩欧美国产激情| 欧美日韩国产成人| 亚洲国产99精品国自产| 久久精品视频网站| 欧美国产高跟鞋裸体秀xxxhd| 欧美精品久久久久| 欧美国产日韩一区二区在线观看| 欧美精品www| 欧美在线播放视频| 国产精品视频久久久久| 欧美成人剧情片在线观看| 欧美大片欧美激情性色a∨久久| 久久色精品视频| 俺去啦;欧美日韩| 欧美日韩在线观看视频| 国产精品爽爽ⅴa在线观看| 成人av在线网址| 国产香蕉精品视频一区二区三区| 国产脚交av在线一区二区| 中国日韩欧美久久久久久久久| 亚洲va欧美va国产综合久久| 国产视频在线观看一区二区| 久久精品国产免费观看| 日韩av大片在线| 91精品美女在线| 久久五月情影视| 国产精品视频导航| 国产精品久久久久久久久免费看| 亚洲精品国产综合久久| 亚洲欧美激情在线视频| 日韩精品欧美国产精品忘忧草| 亚洲精品国精品久久99热一| 不卡av在线播放| 精品国产区一区二区三区在线观看| 日韩精品高清在线观看| 亚洲欧美中文日韩在线| 超碰91人人草人人干| 国产精品网址在线| 欧美一区三区三区高中清蜜桃| 欧美最猛黑人xxxx黑人猛叫黄| 亚洲欧美色婷婷| 欧美午夜精品久久久久久浪潮| 欧美一区二粉嫩精品国产一线天| 成人精品在线观看| 综合136福利视频在线| 亚洲日本aⅴ片在线观看香蕉| 欧美大片免费看| 亚洲成av人片在线观看香蕉| 成人亲热视频网站| 日本高清不卡在线| 深夜福利亚洲导航| 精品国偷自产在线| 日本一区二三区好的精华液| 日韩一区二区精品视频| 亚洲天堂av电影| 国产不卡一区二区在线播放| 91久久国产综合久久91精品网站| 国产精品久久久久免费a∨| 欧美乱大交xxxxx另类电影| 欧美激情videos| 国产成人精品在线视频| 亚洲第一福利在线观看| 国产视频亚洲视频| 久久久久久国产精品美女| 亚洲精品视频播放| 日韩在线播放av| 亚洲女同精品视频| 欧美成人三级视频网站| 久久久国产91| 日韩成人在线视频| 亚洲一区二区三区乱码aⅴ| 亚洲精品国精品久久99热| 日韩精品在线第一页| 欧美最顶级丰满的aⅴ艳星| 成人h视频在线观看播放| 国产在线视频一区| 日韩精品极品视频| 91在线免费看网站| 国产免费久久av| 欧美激情第1页| 少妇激情综合网| 国产亚洲xxx| 亚洲free嫩bbb| 欧美激情精品久久久久久| 日韩欧美有码在线| 久久精品欧美视频| 国产99久久精品一区二区 夜夜躁日日躁| 国产精品久久久久7777婷婷| 欧美激情精品久久久久久变态| 亚洲天堂视频在线观看| 91亚洲va在线va天堂va国| 久久久久久久影视| 精品视频—区二区三区免费| 久久亚洲国产精品| 亚洲男人7777| 国产日韩综合一区二区性色av| 欧美www视频在线观看| 日韩成人在线网站| 亚洲天堂男人的天堂| 国产成人精品在线视频| 欧美日韩一区二区免费在线观看| 国产精品三级网站| 欧美丝袜第一区| 国内外成人免费激情在线视频| 欧美激情综合色综合啪啪五月| 欧美久久精品一级黑人c片| 91久久精品视频| 18性欧美xxxⅹ性满足| 色婷婷久久一区二区| 亚洲精品在线看| 国产精品成人国产乱一区| 77777少妇光屁股久久一区| 精品国产乱码久久久久久天美| 亚洲美女喷白浆| 欧美洲成人男女午夜视频| 高清欧美电影在线| 日韩电视剧在线观看免费网站| 国产综合久久久久久|