MVC中的ELMAH,除了localhost之外不起作用,而/ elmah找不到sproc?

时间:2015-12-02 20:18:19

标签: asp.net-mvc elmah elmah.mvc

我不确定我的ELMAH设置发生了什么,它工作正常,然后停止工作。我使用ELMAH核心和ELMAH MVC。

即使检查我的源代码控制,webconfig中也没有真正改变。我还注意到在实际的ELMAH错误日志数据库中,记录从大约11/5开始就停止了记录。无法在源代码管理中找到任何代码更改以与此一致。

我有两个问题,一个是去myapp/elmah我收到了错误:

  

System.Data.SqlClient.SqlException:找不到存储过程'ELMAH_GetErrorsXml'

不确定原因,因为SPROC肯定存在于我的数据库中。 enter image description here

并且web.config似乎已正确配置为指向该数据库(将在下面发布完整部分)。

第二个问题是当我将应用程序部署到生产环境时,电子邮件通知(可能是日志记录本身)不起作用。在localhost上正常工作。我收到了电子邮件,但在部署到生产时,没有。

以下是web.config的部分:

<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>

<elmah>
   <security allowRemoteAccess="yes"/>
   <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="ElmahDb" />
   <errorMail from="no-reply@mysite" to="myself@mysite" subject="Mysite Error" smtpPort="0" async="false" />
</elmah>

<connectionStrings>
   <add name="ElmahDb" connectionString="Data Source=mydb;Initial Catalog=ErrorLog;Persist Security Info=True;User ID=id;Password=password" providerName="System.Data.SqlClient" />
</connectionStrings>

<appSettings>
   <add key="elmah.mvc.disableHandler" value="false" />
   <add key="elmah.mvc.disableHandleErrorFilter" value="false" />
   <add key="elmah.mvc.requiresAuthentication" value="false" />
   <add key="elmah.mvc.allowedRoles" value="*" />
   <add key="elmah.mvc.route" value="elmah" />
</appSettings>

<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.net>
<mailSettings>
  <smtp deliveryMethod="Network">
    <network defaultCredentials="true" host="mySMTP" port="25" />
  </smtp>
</mailSettings>
 </system.net>

<system.webServer>
   <modules>
     <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>
</system.webServer>

就是这样,我见过的唯一另一件事就是注释掉默认的HandleErrorAttribute,但那些似乎是来自旧文章而且ELMAH MVC无论如何都不再需要它,无论我是否尝试过离开它和评论它出来了:

public static void RegisterGlobalFilters(GlobalFilterCollection filters)
    {
        filters.Add(new HandleErrorAttribute());
    }

它的功能仍然相同。我也尝试为ELMAH启用/禁用remoteAccess,但这也没有做任何事情。在localhost和production上,我在尝试访问/elmah时遇到同样的错误。电子邮件只发送到localhost。那么我的配置有什么问题?为什么我会收到这些错误?

0 个答案:

没有答案