我主要使用Ninject,所以如果我混淆了术语,我会道歉。
我创建了一个记录器模块来使用目标类名作为记录器名来处理NLog。它非常相似:http://docs.autofac.org/en/latest/examples/log4net.html?highlight=log4net
我还在我的服务层创建了一个模块,负责处理所有服务级别注册。看起来像这样:
public class ServiceModule : Module
{
protected override void Load(ContainerBuilder builder)
{
builder.Register(x => new AccountService(x.Resolve<ILogger>()))
.As<IAccountService>()
.InstancePerRequest();
}
}
这是我的autofac注册:
var builder = new ContainerBuilder();
builder.RegisterControllers(Assembly.GetExecutingAssembly());
builder.RegisterModule(new LoggingModule());
builder.RegisterModule(new ServiceModule());
var container = builder.Build();
DependencyResolver.SetResolver(new AutofacDependencyResolver(container));
app.UseAutofacMiddleware(container);
app.UseAutofacMvc();
在运行时,我得到一个异常,说ILogger尚未注册,我是否遗漏了一些有关模块如何工作的信息,导致ILogger无法在我的服务模块中看到?
答案 0 :(得分:2)
模块可以做很多事情:它可以注册新组件和/或订阅 Autofac 事件。
在这种情况下,LoggingModule
不会注册ILog
。它使用Preparing
事件拦截其他组件的准备工作,并添加新Parameter
,如果需要,将创建ILog
。
您将无法解决ILog
,但如果您的AccountService
实施需要ILog
,则会触发以下Parameter
并提供ILog
实施。
new ResolvedParameter(
(p, i) => p.ParameterType == typeof(ILog),
(p, i) => LogManager.GetLogger(p.Member.DeclaringType)
)
您所要做的就是注册您的类型而不尝试显式创建实例:
builder.RegisterType<AccountService>()
.As<IAccountService>()
.InstancePerRequest();