欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

C# log4net 日志输出的实现示例

程序员文章站 2022-06-15 19:13:05
目录第一步:安装log4net第二步:添加log4net.config配置文件第三步:添加日志配置第四步:assemblyinfo.cs中配置 watch = true思路:1.安装插件:安装log4...

思路:
1.安装插件:安装log4net
2.使用配置:添加log4net.config配置文件
3.输出日志文件格式:添加日志配置
4.assemblyinfo.cs中配置

第一步:安装log4net

C# log4net 日志输出的实现示例

C# 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&quot;.txt&quot;"/>
			<param name="rollingstyle" value="date"/>
			<layout type="log4net.layout.patternlayout">
				<param name="conversionpattern" value="%d [%p] - %m%n"/>
			</layout>
		</appender>
	</log4net>
</configuration>

并设置 – 属性 – 复制到输出目录为:始终复制

C# log4net 日志输出的实现示例

第三步:添加日志配置

在文件program.cs应用程序主入口加入:

logutils.setconfig(new fileinfo(application.startuppath + @"\log4net.config"));

C# log4net 日志输出的实现示例

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)]

C# log4net 日志输出的实现示例

最后通过

logutils.error(“错误日志”);
logutils.info(“正常输出日志”);
logutils.warn(“温馨提示日志”);

最后启动项目:会在项目debug目录下输出日志文件夹log内

到此这篇关于c# log4net 日志输出的实现示例的文章就介绍到这了,更多相关c# log4net 日志输出内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!