adv*_*api 4 log4net log4net-configuration
我需要在新的.NET Core应用程序上使用log4net,该应用程序引用一些刚刚使用log4net编写的程序集。我进行了搜索,但是所有示例都将传递FileInfo给,log4net.Config.XmlConfigurator.Configure 但是使用最新版本要求输入第一个类型的参数ILoggerRepository repository
我应该通过什么?
我的代码是
public static void Main(string[] args)
{
var builder = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json");
var configuration = builder.Build();
ContainerConfig.RegisterDependencies(configuration);
MappingConfig.RegisterMapping();
var fileInfo = new FileInfo(@"\config.log4net");
log4net.Config.XmlConfigurator.Configure(null, fileInfo);
var core = ContainerWrapper.Container.GetInstance<ICore>();
core.StartAsync().Wait();
Console.Write("Press a key to exit");
Console.ReadLine();
}
Run Code Online (Sandbox Code Playgroud)
但是null崩溃了
有什么建议么?
您可以repository通过下面的语句获取默认值,
并将该默认值作为Configure方法的参数传递。
ILoggerRepository repository = log4net.LogManager.GetRepository(Assembly.GetCallingAssembly());
Run Code Online (Sandbox Code Playgroud)
根据您的设置,您可能需要使用Assembly.GetExecutingAssembly()代替。
| 归档时间: |
|
| 查看次数: |
925 次 |
| 最近记录: |