我正在使用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>
答案 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
方法。