log4net 不打印日志,无log文件,无日志文件,程序运行正常不报错
问题: 调用log4net写日志;程序正常运行无报错,但是发现没有log日志
尝试方案:[assembly: log4net.Config.XmlConfigurator(Watch = true)] (无效)
分析思路
一、确保你已经引用log4net.dll
二、确保你项目的bin目录下有log4net.dll以及log4.xml文件
三、确定项目存在log4net.config的配置文件
四、log4net.config配置文件的路径是否正确,并且程序在获取log4net.config的配置文件路径是否正确
我的代码
FileInfo configFile = new FileInfo(HttpContext.Current.Server.MapPath("/Configs/log4net.config"));
log4net.Config.XmlConfigurator.Configure(configFile);//加载配置文件
log = log4net.LogManager.GetLogger(typeof(Log));//通过反射获取日志对象实例
我项目保证前三项检查无误,就是处在获取配置文件的时候出错了 ,因为我的是控制台项目
如果你的项目是控制台或者winform项目请继续往下看
控制台项目和winform项目的根目录就在“\bin\Debug\”下面
五、你的项目是否是控制台程序
你应该把log4net.config的配置文件放到“\bin\Debug\”下面,你的输入日志也在“\bin\Debug\”下面;
因为控制台项目和winform项目的根目录就在“\bin\Debug\”下面

如果你的项目类型不是 “Debug”是“Release” ,就在“\bin\Release\”下面
如果你有强迫症,就需要修改你的代码
FileInfo configFile = new FileInfo(MapPath("Configs/log4net.config"));
log4net.Config.XmlConfigurator.Configure(configFile);//加载配置文件
log = log4net.LogManager.GetLogger(typeof(Log));//通过反射获取日志对象实例
/// /// 获取文件路径/// /// /// private static string MapPath(string strPath){if (HttpContext.Current != null){return HttpContext.Current.Server.MapPath(strPath);}else //非web程序引用 {strPath = strPath.Replace("/", "\\");if (strPath.StartsWith("\\")){strPath = strPath.TrimStart('\\');}string baseDirectory = AppDomain.CurrentDomain.BaseDirectory;string _path = "";#region 过滤 bin和Debug目录{string[] str = baseDirectory.Split('\\');foreach (var item in str){Console.WriteLine(item);if (item.ToString() != "bin" && item.ToString() != "Debug"){_path += $"{item}\\";}}_path = _path.Remove(_path.Length - 1, 1);}#endregionreturn System.IO.Path.Combine(_path, strPath);}}
这仅仅是修改了读取log4net.config配置文件方法,
如果你还想修改输出日志的路径;
解决1:就把配置文件里生成日志的路径改成“绝对路径”(全路径)
解决2:读这篇文章《修改log4net日志生成路径》https://blog.csdn.net/cplvfx/article/details/109431116
六、你的项目是否是winForm项目
请看第三项
以上六项都没有检查到问题
七、一定是你log4net.config配置文件里的生成文件路径存在问题
打开log4net.config配置文件文件
找到节点
或
(第一点段代码是相对路径,第二段代码是绝对路径)
如果你的是相对路径,切记路径前面不能带“/”直接文件夹的名称就行了
如果你写成
日志写入就错误了
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
