ELMAH日志记录在SQL Server中

16

我遇到了一个ELMAH的问题。我认为是连接字符串的问题,但是找不出原因。它可以将错误以邮件形式发送给我,但是无法将其记录到sql中。如果问题是权限方面的,我该如何捕获错误以显示它是权限问题?以下是我的web.config文件中与elmah相关的部分:

我有一个ELMAH的问题。我认为是连接字符串的问题,但是找不出原因。它可以将错误以邮件形式发送给我,但是无法将其记录到sql中。如果问题是权限方面的,我该如何捕获错误以显示它是权限问题?以下是我的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" />
  <section name="errorTweet" requirePermission="false" type="Elmah.ErrorTweetSectionHandler, Elmah" />
</sectionGroup>

<connectionStrings>
<add name="ErrorLog" connectionString="Data Source=SQL1;Initial Catalog=ASBESTOS;User Id=MyUserName;Password=MyPassword" providerName="System.Data.SqlClient" />    

<system.web>
    <httpModules>
      <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
      <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
      <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
    </httpModules>
</system.web>
<system.webServer>
<modules runAllManagedModulesForAllRequests="true">
  <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" preCondition="managedHandler" />
  <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" preCondition="managedHandler" />
  <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" preCondition="managedHandler" />
</modules>
<validation validateIntegratedModeConfiguration="false" />

<elmah>
    <security allowRemoteAccess="1" />
    <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="ErrorLog"/>    
    <errorMail from="support@asbestos.phmc.org" to="ethan@phmc.org" subject="Asbestos Error Log" async="true"></errorMail>
  </elmah>
  <location path="elmah.axd" inheritInChildApplications="false">
  <system.web>
      <authorization>
        <allow roles="System" />
        <deny users="*" />
      </authorization>
      <httpHandlers>
        <add verb="POST,GET,HEAD" path="elmah.axd" type="Elmah.ErrorLogPageFactory, Elmah" />
      </httpHandlers>
    </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>
1个回答

18

你的配置看起来不错。我也遇到过无法记录日志的问题。我必须使用连接到数据库的凭据添加Elmah存储过程的执行权限。


2
唉,我真是个笨蛋。在项目进行到一半时,我切换到了Code First,并多次重建了数据库,包括ELMAH表,这意味着表的权限发生了变化。所以,你提供的关于权限的提示是正确的。谢谢。 - Ethan Schofer
1
非常有帮助。附注: 添加执行权限的语法为: GRANT EXECUTE ON [存储过程名称] TO [用户名]。 - Bern

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接