前言
在项目开发、测试以及已经上线的项目中都会存在bug,而如果我们在项目的各个阶段都能及时的监控系统出现的任何问题,那么对于我们开发人员来说完善系统,减少bug,甚至安全防护等都是一件十分有利的事情。网上有很多的系统日志记录框架,ELMAH在我们使用mvc开发的时候提供了简单便捷的服务,这个框架的好处是我们不仅可以通过本地可以记录系统错误,而且可以配置远程发送错误,如利用邮箱传送错误等,这样我们便可以随时监控我们的项目及时处理问题,接下来简单的配置一下ELMAH来记录mvc项目的错误。
步骤
1、建立一个基本的mvc4程序
新建——>项目——>web项目——>ASP.NET MVC4 web应用程序,我们选择一个不带任何controller的基本项目。
2、使用NugGet程序包管理工具安装ELMAH
在项目引用出右击选择管理nuget程序包,然后联机搜索ELMAH,如下图:
选择安装ELMAH,项目自动添加其依赖的类库并自动配置web.config
3、配置节点
查看web.config我们可以看到ELMAH为我们添加的配置文件,如下:
<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> <security allowRemoteAccess="yes" /> </elmah> <system.web> <httpModules> <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" /> </httpModules> <httpHandlers> <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" /> </httpHandlers> </system.web> <system.webServer> <modules> <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" /> </modules> <handlers> <add name="Elmah" verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" /> </handlers> </system.webServer> </configuration>
接下来修改一下Global.asax,注释掉mvc自带的异常过滤器
运行项目,由于我们没有添加controller的原因,系统会出现如下错误提示:
这样的错误十分不友好,直接看是看不出任何错误的,下面查看ELMAH的错误信息。
3、查看错误信息
在地址栏输入http://localhost:10140/elmah.axd查看日志,如下图
点击Details查看错误详情:
这是一个错误的详细信息页,相信这个可以很顺利的帮我们解决系统问题。
总结:
以上就是ELMAH在mvc中的简单配置,相信一个好的日志记录组件能给我们的开发带来更便利的好处,其他更多的功能留待以后在进行探讨。
本人初次使用本组件,若有问题欢迎指出。