log4net - 使用 .NET Core 应用程序进行 Log4Net 配置
问题描述
我需要在一个新的 .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();
}
但随之null
崩溃
有什么建议么?
解决方案
repository
您可以通过下面的语句获取默认值,
并将其作为Configure
方法的参数传递。
ILoggerRepository repository = log4net.LogManager.GetRepository(Assembly.GetCallingAssembly());
根据您的设置,您可能需要Assembly.GetExecutingAssembly()
改用。
推荐阅读
- wpf - 创建多个扩展控件
- c# - 当我尝试发送 HTTPS 请求时,Unity 返回 NULL
- javascript - 比较json对象数组中的值
- javascript - 角度测试:预期间谍 AuthenticationService.checkUsername 已被调用
- reactjs - 在 React 中作为道具传递的参数化函数的奇怪行为
- uwp - 用Raspberry PI3 Windows 10 iot读取PT1000
- r - caretEnsemble::caretList 不工作 svmRBF,r 中的 xgboost
- java - Java:调整大小方法,有人可以解释一下吗?
- c# - Unity2D:缩放游戏对象而不缩放其子对象
- java - 如何使用 DocumentBuilder 通过 Socket InputStream 解析 Xml 文档而不关闭流?