我主要使用 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 在我的服务模块中不可见的一些内容?