错误日志记录工具elmah。

机器:window 7 操作系统,家庭版,坑爹的不能安装iis,只能在本地调试运行。

项目:asp.net mvc4

在自己当前的项目中添加elmah.dll的引用,这里也可以通过nugit通过命令自动部署,具体参考博客:

本地的webconfig应该如下配置:

1.添加如下代码到<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>

2.添加如下代码到根节点:

复制代码
<elmah>
        <!--是否允许远程访问。0代表否、1代表是-->
        <security allowRemoteAccess="0"/>
        <!--错误信息记录到文件中-->
        <errorLog type="Elmah.XmlFileErrorLog, Elmah" logPath="~/logs"/>存放xml的文件目录,也可以如D:\logs注意要给对应目录写入权限。
<!--错误信息发送EMAIL,多个EMAIL间用逗号分隔。--> <errorMail from="发件箱" to="收件箱,逗号分隔" subject=" 邮件主题" async="true" smtpPort="25" smtpServer="邮件服务器" userName="发件人用户名" password="密码"/> </elmah>
复制代码

3.在system.web配置节点添加如下代码:

复制代码
      <httpHandlers>
          <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah"/>
      </httpHandlers>
      <httpModules>
          <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
          <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah"/>
      </httpModules>
复制代码

运行自己的程序,然后访问例如:http://localhost:1149/elmah.axd,出现noerror提示的页面,则说明配置成功。

然后自己在自己的应用程序中找点麻烦,让它黄页,刷新刚才的页面,就会出现对应的一条错误记录。同事,如果设置邮箱成功的话,邮箱会受到一封邮件。

而server2008服务器上之后就不能这样配置啦,如果你访问站点\elmah.axd会出现提示404错误,然后你修改操作3为如下的配置即可搞定:

修改后的3,添加如下代码到system.webservers节点下:注意不要重复拉handlers和modules节点。(默认handlers和modules节点都是存在的。

复制代码
    <handlers>
  <add name="ELMAH" verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" preCondition="integratedMode" />
        </handlers>
      <modules runAllManagedModulesForAllRequests="true" >
          <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah"/>
          <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah"/>
      </modules>
复制代码

大体流程就是这样,具体细节我没有深究,现在不清楚为什么404错误不提醒,只对黄页错误给予发送邮件提示。

有知道的给提示一下。

posted @ 2013-05-14 11:29  赤狐(zcm123)  阅读(267)  评论(0编辑  收藏  举报