Filter exceptions logged in ELMAH

By default, all exceptions are logged in ELMAH's database. You can filter out exceptions and thus exclude them from the logs, for example, to exclude exceptions thrown from a certain IP range address. This address may correspond to your company's IP address and thus exclude logs made by your QAs or developers.

To filter and exclude exceptions from the log, you modify your application's web.config file. The following example demonstrates how to exclude from the logs all exceptions of type HttpStatusCode with value 404:

  1. Configure an additional Elmah.ErrorFilterModule module. Add the module after all other ELMAH logging modules:

    <httpModules>
    ...
    <add name="ErrorLog" type="Elmah.ErrorLogModule, Elmah" />
    <add name="ErrorMail" type="Elmah.ErrorMailModule, Elmah" />
    <add name="ErrorFilter" type="Elmah.ErrorFilterModule, Elmah" />
    ...
    </httpModules>
  2. In the configSections section, add a dedicated configuration section with Elmah.ErrorFilterSectionHandler for the filtering assertions:

    <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>
  3. In the modules section, add the ErrorFilterModule:

    <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>
  4. In the elmah group, add the <errorFilter> section:

    <elmah>
    ...
    <errorLog type="Elmah.SqlErrorLog, Elmah" connectionStringName="elmah-sqlserver" />
    <errorFilter>
    <test>
    <equal binding="HttpStatusCode" value="404" type="Int32" />
    </test>
    </errorFilter>
    </elmah>

Increase your Sitefinity skills by signing up for our free trainings. Get Sitefinity-certified at Progress Education Community to boost your credentials.

Get started with Integration Hub | Sitefinity Cloud | Sitefinity SaaS

This free lesson teaches administrators, marketers, and other business professionals how to use the Integration hub service to create automated workflows between Sitefinity and other business systems.

Web Security for Sitefinity Administrators

This free lesson teaches administrators the basics about protecting yor Sitefinity instance and its sites from external threats. Configure HTTPS, SSL, allow lists for trusted sites, and cookie security, among others.

Foundations of Sitefinity ASP.NET Core Development

The free on-demand video course teaches developers how to use Sitefinity .NET Core and leverage its decoupled architecture and new way of coding against the platform.

Was this article helpful?