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配置文件文件

找到节点

(第一点段代码是相对路径,第二段代码是绝对路径)

如果你的是相对路径,切记路径前面不能带“/”直接文件夹的名称就行了

如果你写成日志写入就错误了

 

 

 


本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!

相关文章

立即
投稿

微信公众账号

微信扫一扫加关注

返回
顶部