使用Ninject声明一个新的log4net记录器

时间:2014-12-12 13:41:06

标签: c# logging asp.net-web-api ninject log4net

我正在使用C#,.NET Framework 4.0,Ninject 3.2.2.0和log4net 2.0.3开发Web Api应用程序。

现在,我只使用一个记录器。这是我在NinjectConfigurator类上配置的方式。

private void ConfigureLog4net(IKernel container)
{
    log4net.Config.XmlConfigurator.Configure();
    var loggerForWebSite = LogManager.GetLogger("AutomationMiddlewareWebsite");
    container.Bind<ILog>().ToConstant(loggerForWebSite);
}

但是,我需要使用另一个记录器。 使用,Ninject,我该怎么办? 我不知道如何在NinjectConfigurator课程中声明这个新的记录器。 < / p>

如果我声明另一个记录器,我不能使用ILog将它绑定到我的新记录器。也许,我可以使用绑定参数...

这是log4net中的Web.config配置。

<log4net xsi:noNamespaceSchemaLocation="http://csharptest.net/downloads/schema/log4net.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender">
      <file value="d:\\MyProject.Web.Api.log" />
      <appendToFile value="true" />
      <rollingStyle value="Date" />
      <datePattern value=".yyyyMMdd.lo\g" />
      <maximumFileSize value="5MB" />
      <maxSizeRollBackups value="-1" />
      <countDirection value="1" />
      <layout type="log4net.Layout.PatternLayout">
        <conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
      </layout>
    </appender>
    <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender">
      <layout type="log4net.Layout.PatternLayout">
          <conversionPattern value="%date %-5level [%thread] %logger - %message%newline%exception" />
      </layout>
    </appender>
    <logger name="MyProjectWebsite">
      <level value="DEBUG" />
    </logger>
    <root>
      <level value="DEBUG" />
      <appender-ref ref="RollingLogFileAppender" />
    </root>
  </log4net>

1 个答案:

答案 0 :(得分:3)

您可以绑定多个记录器.ToConstant(...)并使用.WhenInjectedInto<SomeClass>()之类的Contextual Binding facilities

Bind<Ilog>().ToConstant(logger1)
    .WhenInjectedInto<Class1>();

但是如果你需要将记录器注入很多可能会带来很多工作并且可维护性很差的类。

在这种情况下,您可以选择使用ToMethod(..)绑定或使用provider并根据上下文创建记录器,如下所示:

Bind<ILog>().ToMethod(context =>
                 LogManager.GetLogger(context.Request.ParentContext.Plan.Type));

context.Request.ParentContext.Plan.Type是注入的类型ILog

当然,您可以使用一些精心设计的方案来确定基于类名,类程序集,类命名空间等使用哪个记录器。您可以命名它。

如果您只想要一个或两个特定记录器,则可以使用上下文绑定(When(...))方法,如果更多,则可以使用ToMethod(...)IProvider方法。