C# log4net 日志输出的实现示例
作者:letisgo5 发布时间:2023-04-27 06:50:12
标签:C#,log4net,日志,输出
思路:
1.安装插件:安装log4net
2.使用配置:添加log4net.config配置文件
3.输出日志文件格式:添加日志配置
4.AssemblyInfo.cs中配置
第一步:安装log4net
第二步:添加log4net.config配置文件
新增log4net.config配置文件,内容如下,与Program.cs同一目录即可。
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler,log4net"/>
</configSections>
<log4net>
<!--level取值:OFF FATAL ERROR WARN INFO DEBUG ALL -->
<logger name="loginfo">
<level value="ALL"/>
<appender-ref ref="InfoAppender"/>
</logger>
<appender name="InfoAppender" type="log4net.Appender.RollingFileAppender">
<param name="File" value="log\\"/>
<lockingModel type="log4net.Appender.FileAppender+MinimalLock"/>
<param name="AppendToFile" value="true"/>
<param name="MaxFileSize" value="10240"/>
<param name="StaticLogFileName" value="false"/>
<param name="DatePattern" value="yyyy-MM-dd".txt""/>
<param name="RollingStyle" value="Date"/>
<layout type="log4net.Layout.PatternLayout">
<param name="ConversionPattern" value="%d [%p] - %m%n"/>
</layout>
</appender>
</log4net>
</configuration>
并设置 – 属性 – 复制到输出目录为:始终复制
第三步:添加日志配置
在文件Program.cs应用程序主入口加入:
LogUtils.SetConfig(new FileInfo(Application.StartupPath + @"\log4net.config"));
LogUtils.cs 写入日志公共类
class LogUtils
{
private static readonly ILog loginfo = LogManager.GetLogger("loginfo");
/// <summary>
/// 从缺省配置文件获取日志配置
/// </summary>
public static void SetConfig()
{
XmlConfigurator.Configure();
}
/// <summary>
/// 从指定配置文件获取日志配置
/// </summary>
/// <param name="configFile">指定的配置文件</param>
public static void SetConfig(FileInfo configFile)
{
XmlConfigurator.Configure(configFile);
}
/// <summary>
/// 生成分类日志
/// </summary>
/// <param name="info">日志信息</param>
/// <param name="dirName">保存目录名,形如d:\log\aaa</param>
private static void WriteSortLog(string info, string dirName)
{
try
{
if (false == System.IO.Directory.Exists(dirName))
{
System.IO.Directory.CreateDirectory(dirName);
}
string path = dirName + "\\" + DateTime.Now.ToString("yyyyMMdd") + ".txt";
StreamWriter sw = new StreamWriter(path, true, System.Text.Encoding.Default);
sw.WriteLine(DateTime.Now.ToString("HH:mm:ss: ") + info);
sw.Close();
}
catch (Exception ex)
{
string expMsg = "WriteSortLog异常:" + ex.Message + Environment.NewLine + ex.StackTrace;
if (ex.InnerException != null)
expMsg += Environment.NewLine + "InnerException:" + ex.InnerException.Message;
Error(expMsg, ex);
}
}
/// <summary>
/// Info级 常规日志
/// </summary>
/// <param name="info">日志信息</param>
public static void Info(string info)
{
if (loginfo.IsInfoEnabled)
{
loginfo.Info(info);
}
}
/// <summary>
/// Info 先生成常规日志,然后在指定目录另外创建一份日志
/// 主要用来需要对日志进行分类时使用
/// </summary>
/// <param name="info"></param>
/// <param name="dirName"></param>
public static void Info(string info, string dirName)
{
if (loginfo.IsInfoEnabled)
{
//生成常规日志
loginfo.Info(info);
//生成分类日志
WriteSortLog(info, dirName);
}
}
/// <summary>
/// Debug级 常规日志
/// </summary>
/// <param name="info">日志信息</param>
public static void Debug(string info)
{
if (loginfo.IsDebugEnabled)
{
loginfo.Debug(info);
}
}
/// <summary>
/// Debug级 异常日志
/// </summary>
/// <param name="info">日志信息</param>
/// <param name="exp">异常信息</param>
public static void Debug(string info, Exception exp)
{
if (loginfo.IsDebugEnabled)
{
loginfo.Debug(info, exp);
}
}
/// <summary>
/// Error级 常规的日志
/// </summary>
/// <param name="info">日志信息</param>
public static void Error(string info)
{
if (loginfo.IsErrorEnabled)
{
loginfo.Error(info);
}
}
/// <summary>
/// Error 异常日志
/// </summary>
/// <param name="info">日志信息</param>
/// <param name="exp">异常信息</param>
public static void Error(string info, Exception exp)
{
if (loginfo.IsErrorEnabled)
{
loginfo.Error(info, exp);
}
}
/// <summary>
/// Fatal级 常规日志
/// </summary>
/// <param name="info">日志信息</param>
public static void Fatal(string info)
{
if (loginfo.IsFatalEnabled)
{
loginfo.Fatal(info);
}
}
/// <summary>
/// Fatal级 异常日志
/// </summary>
/// <param name="info">日志信息</param>
/// <param name="exp">异常信息</param>
public static void Fatal(string info, Exception exp)
{
if (loginfo.IsFatalEnabled)
{
loginfo.Fatal(info, exp);
}
}
/// <summary>
/// Warn级 常规日志
/// </summary>
/// <param name="info">日志信息</param>
public static void Warn(string info)
{
if (loginfo.IsWarnEnabled)
{
loginfo.Warn(info);
}
}
/// <summary>
/// Warn级 异常日志
/// </summary>
/// <param name="info">日志</param>
/// <param name="exp">异常信息</param>
public static void Warn(string info, Exception exp)
{
if (loginfo.IsWarnEnabled)
{
loginfo.Warn(info, exp);
}
}
}
第四步:AssemblyInfo.cs中配置 Watch = true
在项目Properties文件夹下AssemblyInfo.cs中加入:
[assembly: log4net.Config.XmlConfigurator(Watch = true)]
最后通过
LogUtils.Error(“错误日志”);
LogUtils.Info(“正常输出日志”);
LogUtils.Warn(“温馨提示日志”);
最后启动项目:会在项目debug目录下输出日志文件夹log内
来源:https://blog.csdn.net/qq_16771097/article/details/120845149
0
投稿
猜你喜欢
- import java.util.Scanner;public class VariableExchange { &n
- 序言使用SpringBoot创建定时任务非常简单,目前主要有以下三种创建方式:一、基于注解(@Scheduled)二、基于接口(Schedu
- 本文实例讲述了java GUI编程之监听操作。分享给大家供大家参考,具体如下:当点击Frame中的component组件时,会产生相应的效果
- 简单工厂简单工厂模式是属于创建型模式,是工厂模式的一种。简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。定义了一个创建对象的类,由
- 想必我们在做项目的时候,都会遇到服务端与客户端交互数据。一般情况下我们都会采用json格式或者xml格式,将服务端的数据转换成这两种格式之一
- 一、HttpBasic模式的应用场景HttpBasic登录验证模式是Spring Security实现登录验证最简单的一种方式,也可以说是最
- 1.前言NameServer主要作用是为消息消费者和消息生产者提供关于主题Topic的路由信息,那么NameServer需要存储路由的基本信
- 这篇文章主要介绍了SpringBoot Jpa分页查询配置方式解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价
- 本文实例总结了Android开发中Toast显示消息的方法。分享给大家供大家参考,具体如下:Android中提供一种简单的Toast消息提示
- 本文实例讲述了Java Socket实现传输压缩对象的方法。分享给大家供大家参考,具体如下:前面文章《Java Socket实现的传输对象功
- 首先说一下最近自己遇到的一个坑:@Transactionalservice A(){try{insert();serviceB.update
- 前言很多时候,当你以为掌握了事实真相的时间,如果你能再深入一点,你可能会发现另外一些真相。比如面向切面编程的最佳编程实践是AOP,AOP的主
- 一. 为什么要使用接口假如有一个需求:要求实现防盗门的功能。门有"开"和"关"的功能,锁有"
- 废话不多说,直接上代码package com.ncu.list;/** * * 顺序结构线性列表 *&nbs
- String password = RandomUtil.generateString(10);源码如下:package com.javan
- 日志过滤对于一个网站日志,首先要对它进行过滤,删除一些不必要的信息,我们通过scala语言来实现,清洗代码如下,代码要通过别的软件打包为ja
- Java 的线程支持提供了一些便捷的工具方法,通过这些便捷的工具方法可以很好地控制线程的执行。join 线程Thread 提供了让一个线程等
- 自定义注解实现接口幂等性方式近期需要对接口进行幂等性的改造,特此记录下。背景在微服务架构中,幂等是一致性方面的一个重要概念。一个幂等操作的特
- Eclipse 最佳字体 推荐:步骤:Eclipse->Windows[窗口]->Preferences[首选项]->Ge
- Java代码1. ReentrantLock加锁阻塞,一个condition对应一个线程,以便于唤醒时使用该condition一定会唤醒该线