ASP.NET MVC-简单例子-配置日志文件-log4net

环境:

win10,SQL Server 2008 R2


安装

使用NuGet

安装时发现报错并无法安装:

shell 复制代码
现有 packages.config 文件中检测到一个或多个未解析包依赖项约束。必须解析所有依赖项约束以添加或更新包。如果正在更新这些包,则可忽略此消息,如果没有更新这些包,错误可能阻止当前包操作: 'EntityFramework.zh-Hans 6.2.0 约束: EntityFramework (= 6.2.0)'
无法解析依赖项。"EntityFramework 6.4.4"与 'EntityFramework.zh-Hans 6.2.0 约束: EntityFramework (= 6.2.0)' 不兼容。

查询后得知:EntityFramework.zh-Hans 是 Entity Framework 的中文本地化包,用于将 Entity Framework 的个包通常用于将 Entity Framework 在用户界面中显示的文本本地化成中文。

考虑到我不需要这个功能,就直接卸载了这个包。报错解除,正常安装。

配置

  1. 打开项目根目录下的Web.config文件,在<configSections>下增加一条语句:
xml 复制代码
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>

如果不加这句会报错:

shell 复制代码
配置错误	   无法读取配置节"log4net",因为它缺少节声明

然后在</configuration>前加入下面这段:

xml 复制代码
	<log4net>
		<appender name="FileAppender" type="log4net.Appender.FileAppender">
			<file value="logFile.log" />
			<appendToFile value="true" />
			<layout type="log4net.Layout.PatternLayout">
				<conversionPattern value="%date [%thread] %-5level %logger [%property{NDC}] - %message%newline" />
			</layout>
		</appender>
		<root>
			<level value="DEBUG" />
			<appender-ref ref="FileAppender" />
		</root>
	</log4net>

就是放在这个位置:

  1. 打开Global.asax.cs文件,在函数Application_Start中增加一句:
csharp 复制代码
log4net.Config.XmlConfigurator.Configure();

使用

比如在HomeController里:

csharp 复制代码
public class HomeController : Controller
{
    // use log
    private static readonly log4net.ILog log = log4net.LogManager.GetLogger(System.Reflection.MethodBase.GetCurrentMethod().DeclaringType);
    
    public ActionResult Index()
    {
        log.Debug("Debug message");
        log.Info("Info message");
        log.Warn("Warn message");
        log.Error("Error message");
        log.Fatal("Fatal message");
        return View();
    }
    .....
}

此时项目根目录下产生文件logFile.log,内容为:

shell 复制代码
2024-06-28 16:58:27,429 [9] DEBUG WebApplication1.Controllers.HomeController [(null)] - Debug message
2024-06-28 16:58:27,452 [9] INFO  WebApplication1.Controllers.HomeController [(null)] - Info message
2024-06-28 16:58:27,452 [9] WARN  WebApplication1.Controllers.HomeController [(null)] - Warn message
2024-06-28 16:58:27,452 [9] ERROR WebApplication1.Controllers.HomeController [(null)] - Error message
2024-06-28 16:58:27,453 [9] FATAL WebApplication1.Controllers.HomeController [(null)] - Fatal message
相关推荐
百事牛科技几秒前
高效办公技巧:如何取消PPT以“只读方式”打开?
windows·powerpoint
BIBI20492 分钟前
VirtualBox 7.x 安装 Ubuntu 24 及增强功能配置、克隆虚拟机教程
linux·windows·ubuntu·环境搭建·安装教程·最佳实践·virtualbox
Master_H_ice10 小时前
Claude Code安装试用记录(Windows)
windows·claude code
芳草萋萋鹦鹉洲哦12 小时前
【windows】nginx如何注册为开机自启的服务(WinSW实现)
运维·windows·nginx
好名字更能让你们记住我12 小时前
vmware虚拟机安装Windows10镜像【超详细图文版】!!!
windows·系统安装·vmware·虚拟机·图文教程
副露のmagic13 小时前
字符串章节 leetcode 思路&实现
windows·python·leetcode
Java 码农14 小时前
Windows 系统安装 Claude Code 完整教程
windows
极创信息15 小时前
信创软件安全加固指南,信创软件的纵深防御体系
java·大数据·数据库·金融·php·mvc·软件工程
无籽西瓜a16 小时前
详解bat脚本:语法、常见用法、注意事项、示例
windows·batch·cmd·自动化工具
无极低码19 小时前
windows 程连接 Oracle 报 ORA-12541
数据库·windows·oracle