Log4net发送日志邮件(实例下载)以及Log4Net配置详解

2024-01-22 21:32

本文主要是介绍Log4net发送日志邮件(实例下载)以及Log4Net配置详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目中要使用Log4net组件发送日志文件,大概需要以下几步:

首先,建立Log4net配置文件


<?xml version="1.0" encoding="utf-8" ?>
<configuration><configSections><section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/></configSections><log4net><root><!--(高) OFF > FATAL > ERROR > WARN > INFO > DEBUG > ALL (低) --><level value="all" /><appender-ref ref="ColoredConsoleAppender"/><appender-ref ref="RollingLogFileAppender"/><appender-ref ref="SmtpAppender"/></root><!--文件显示日志--><appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender"><!--日志路径--><param name= "File" value= "log/log-file.txt"/><!--是否是向文件中追加日志--><param name= "AppendToFile" value= "true"/><!--log保留天数--><param name= "MaxSizeRollBackups" value= "10"/><!--日志文件名是否是固定不变的--><param name= "StaticLogFileName" value= "false"/><!--日志文件名格式为:2008-08-31.log--><param name= "DatePattern" value= "yyyy-MM-dd&quot;.log&quot;"/><!--日志根据日期滚动--><param name= "RollingStyle" value= "Date"/><layout type="log4net.Layout.PatternLayout"><!--%m(message):输出的日志消息,如ILog.Debug(…)输出的一条消息%n(new line):换行%d(datetime):输出当前语句运行的时刻%r(run time):输出程序从运行到执行到当前语句时消耗的毫秒数%t(thread id):当前语句所在的线程ID%p(priority): 日志的当前优先级别,即DEBUG、INFO、WARN…等%c(class):当前日志对象的名称,例如:模式字符串为:%-10c -%m%n代码为:ILog log=LogManager.GetLogger(“Exam.Log”);log.Debug(“Hello”);则输出为下面的形式:Exam.Log       - Hello%L:输出语句所在的行号%F:输出语句所在的文件名%-数字:表示该项的最小长度,如果不够,则用空格填充--><param name="ConversionPattern" value="%n%d [%t] %-5p %c - %m%n %loggername" /></layout><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="DEBUG" /><param name="LevelMax" value="FATAL" /></filter></appender><!-- 控制台前台显示日志 --><appender name="ColoredConsoleAppender" type="log4net.Appender.ColoredConsoleAppender"><mapping><level value="WARN" /><foreColor value="Yellow, HighIntensity" /></mapping><mapping><level value="ERROR" /><foreColor value="Red, HighIntensity" /></mapping><mapping><!--定义日志输出级别--><level value="Info" /><foreColor value="Green" /></mapping><layout type="log4net.Layout.PatternLayout"><!--<conversionPattern value="%n%date{HH:mm:ss,fff} [%-5level] %m" />--></layout><filter type="log4net.Filter.LevelRangeFilter"><param name="LevelMin" value="Info" /><param name="LevelMax" value="Fatal" /></filter></appender><!--发送邮件通知异常信息--><appender name="SmtpAppender" type="log4net.Appender.SmtpAppender"><authentication value="Basic" /><!--接收方邮箱地址,多个接收方以","隔开--><to value="523673444@qq.com" /><!--测试126邮箱可以发邮件,QQ邮箱不能发--><!--发送方邮箱地址--><from value="您的126邮箱账号" /><!--发送发邮箱地址--><username value="您的126邮箱账号" /><!--发送方邮箱登录密码--><password value="您的126邮箱密码" /><!--邮件主题--><subject value="homework2应用程序错误" /><!--邮件服务器--><smtpHost value="smtp.126.com" /><port value ="25"/><!--设置所使用的循环缓冲区的大小,默认为512个事件,若将此值设置为小于等于1,将没有缓冲,记录事件会同步交付--><bufferSize value="1" /><!--超长部分是否丢弃--><lossy value="true" /><!-- 下面的定义, 就是 日志级别 大于 WARN 的, 才发邮件.  --><evaluator type="log4net.Core.LevelEvaluator"><threshold value="FATAL"/></evaluator><!-- 下面是 定义邮件的格式 (好多换行啊) --><layout type="log4net.Layout.PatternLayout"><param name="ConversionPattern" value="%n%d [%t] %-5p %c - %m%n %loggername" /></layout></appender></log4net>
</configuration>

其次,建立LogHelper类统一提供logger实例


public class LogHelper : Singleton<LogHelper>{public LogHelper(){var logCfg = new FileInfo(AppDomain.CurrentDomain.BaseDirectory + "configfiles/log4net.config");XmlConfigurator.ConfigureAndWatch(logCfg);}public ILog Logger{get { return LogManager.GetLogger("homework2.logger"); }}/// <summary>/// 异步的方式记录日志/// </summary>/// <param name="errMsg"></param>public void AsyncLogger(string errMsg){Task.Factory.StartNew(() => Logger.Fatal(errMsg));}}


接下来,就可以在程序中使用提供的LogHelper类来记录日志了,如下

  1. 调用异步方法记录日志

EventModelList.Find(e => typeof(T).Name.Equals(e.Name)).EventList.ToList().ForEach(str =>{t.FireEventHander += () =>LogHelper.Instance.AsyncLogger(str);});



2.调用logger对象记录日志

class Program{static void Main(string[] args){try{//TODO:一些代码}catch (Exception ex){LogHelper.Instance.Logger.Error(ex.Message);LogHelper.Instance.Logger.Error(ex.StackTrace);}Console.ReadKey();}}

附上效果图一张


实例下载

这篇关于Log4net发送日志邮件(实例下载)以及Log4Net配置详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/634294

相关文章

VScode连接远程Linux服务器环境配置图文教程

《VScode连接远程Linux服务器环境配置图文教程》:本文主要介绍如何安装和配置VSCode,包括安装步骤、环境配置(如汉化包、远程SSH连接)、语言包安装(如C/C++插件)等,文中给出了详... 目录一、安装vscode二、环境配置1.中文汉化包2.安装remote-ssh,用于远程连接2.1安装2

Java中注解与元数据示例详解

《Java中注解与元数据示例详解》Java注解和元数据是编程中重要的概念,用于描述程序元素的属性和用途,:本文主要介绍Java中注解与元数据的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参... 目录一、引言二、元数据的概念2.1 定义2.2 作用三、Java 注解的基础3.1 注解的定义3.2 内

Java中使用Java Mail实现邮件服务功能示例

《Java中使用JavaMail实现邮件服务功能示例》:本文主要介绍Java中使用JavaMail实现邮件服务功能的相关资料,文章还提供了一个发送邮件的示例代码,包括创建参数类、邮件类和执行结... 目录前言一、历史背景二编程、pom依赖三、API说明(一)Session (会话)(二)Message编程客

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

使用Python实现操作mongodb详解

《使用Python实现操作mongodb详解》这篇文章主要为大家详细介绍了使用Python实现操作mongodb的相关知识,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、示例二、常用指令三、遇到的问题一、示例from pymongo import MongoClientf

一文详解Python中数据清洗与处理的常用方法

《一文详解Python中数据清洗与处理的常用方法》在数据处理与分析过程中,缺失值、重复值、异常值等问题是常见的挑战,本文总结了多种数据清洗与处理方法,文中的示例代码简洁易懂,有需要的小伙伴可以参考下... 目录缺失值处理重复值处理异常值处理数据类型转换文本清洗数据分组统计数据分箱数据标准化在数据处理与分析过

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库