asp.net core中使用log4net

asp.net core中使用log4net和之前的ASP.NETMVC中的使用LOG4NET的方法有些不同,这里先记录一下,使用步骤如下:1.建立ASP.NETCORE项目中,NUGET中搜索log4net后下载安装2.根目录建立log4net.config文件,内容如下:<?xmlversion="1.0"encoding="utf-8"?><configuration> <!–T…

大家好,又见面了,我是你们的朋友全栈君。

和之前的ASP.NET MVC中的使用LOG4NET的方法有些不同,这里先记录一下,使用步骤如下 :

1. 建立 ASP.NET CORE项目中,NUGET中搜索log4net后下载安装

2. 根目录建立 log4net.config文件,内容如下:

<?xml version=”1.0″ encoding=”utf-8″ ?>
<configuration>
  <!– This section contains the log4net configuration settings –>
  <log4net>
    <appender name=”ConsoleAppender” type=”log4net.Appender.ConsoleAppender”>
      <layout type=”log4net.Layout.PatternLayout” value=”%date [%thread] %-5level %logger – %message%newline” />
    </appender>

    <!–<appender name=”FileAppender” type=”log4net.Appender.FileAppender”>
      <file value=”log-file.log” />
      <appendToFile value=”true” />
      <layout type=”log4net.Layout.PatternLayout”>
        <conversionPattern value=”%date [%thread] %-5level %logger [%property{NDC}] – %message%newline” />
      </layout>
    </appender>–>

    <appender name=”RollingLogFileAppender” type=”log4net.Appender.RollingFileAppender”>
      <file value=”logfile/” />
      <appendToFile value=”true” />
      <rollingStyle value=”Composite” />
      <staticLogFileName value=”false” />
      <datePattern value=”yyyyMMdd’.log'” />
      <maxSizeRollBackups value=”10″ />
      <maximumFileSize value=”1MB” />
      <layout type=”log4net.Layout.PatternLayout”>
        <conversionPattern value=”%date [%thread] %-5level %logger [%property{NDC}] – %message%newline” />
      </layout>
    </appender>

    <!– Setup the root category, add the appenders and set the default level –>
    <root>
      <level value=”ALL” />
      <appender-ref ref=”ConsoleAppender” />
      <appender-ref ref=”FileAppender” />
      <appender-ref ref=”RollingLogFileAppender” />
    </root>

  </log4net>
</configuration>

3. Startup.cs文件中的Startup方法和ConfigureServices方法里的AddMvc代码改下,核心代码如下,记得引用相应的命名空间:

        //log4net日志
        public static ILoggerRepository repository { get; set; }

        public Startup(IConfiguration configuration)
        {

            Configuration = configuration;

            //加载log4net日志配置文件
            repository = LogManager.CreateRepository(“NETCoreRepository”);
            XmlConfigurator.Configure(repository, new FileInfo(“log4net.config”));
        }

        public IConfiguration Configuration { get; }

        // This method gets called by the runtime. Use this method to add services to the container.
        public void ConfigureServices(IServiceCollection services)
        {

            services.AddMvc(options =>
            {

                options.Filters.Add<Models.HttpGlobalExceptionFilter>(); //加入全局异常类
            });
        }

4. Models文件夹中建立 HttpGlobalExceptionFilter.cs 类,用于全局异常后记录到日志中,内容代码如下 :

using log4net;
using Microsoft.AspNetCore.Mvc.Filters;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;

namespace WebApplication1.Models
{

    /// <summary>
    /// 全局异常类
    /// </summary>
    public class HttpGlobalExceptionFilter : IExceptionFilter
    {

        private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HttpGlobalExceptionFilter));
        public void OnException(ExceptionContext context)
        {

            log.Error(context.Exception);
        }
    }
}

5. 下面是控制器的代码,有异常会自动记录下来,用那个log也能手工记录日志信息

using System;

using System.Collections.Generic;

using System.Diagnostics;

using System.Linq;

using System.Threading.Tasks;

using log4net;

using Microsoft.AspNetCore.Mvc;

using WebApplication1.Models;

namespace WebApplication1.Controllers

{

    public class HomeController : Controller

    {

        private ILog log = LogManager.GetLogger(Startup.repository.Name, typeof(HttpGlobalExceptionFilter));

        public IActionResult Index()

        {

            throw new Exception(“牛腩自定义异常!!!”);  //有异常则会记录到logfile文件夹中

            return View();

        }

        public IActionResult About()

        {

            ViewData[“Message”] = “Your application description page.”;

            log.Info(“打开about页面了!!!”); //普通的记录日志

            return View();

        }

 

    }

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/157434.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 汇编指令和机器码的对应表pdf_机器码与汇编对应表

    汇编指令和机器码的对应表pdf_机器码与汇编对应表一、状态寄存器PSW(ProgramFlag)程序状态字寄存器,是一个16位寄存器,由条件码标志(flag)和控制标志构成,如下所示:1514131211109876543210   OFDFIFTFSFZF AF PF CF条件码:①OF(OverflowFlag)溢出标志。溢出时为1,否则置0。②SF(SignFlag)符号标志。结果为负时置1,否则置0.③ZF(ZeroFlag)零标志,运算结果为0时ZF位置1,否则…

    2022年8月30日
    1
  • 多进程 python_python多进程编程

    多进程 python_python多进程编程进程前置知识点进程:一个程序运行起来后,代码+用到的资源称之为进程,它是操作系统分配资源的基本单元。并发:指的是任务数多余cpu核数,通过操作系统的各种任务调度算法,实现用多个任务“一起”执行

    2022年7月29日
    7
  • 宿主机ping不通docker容器_kali虚拟机ping不通

    宿主机ping不通docker容器_kali虚拟机ping不通问题描述:  Docker网络模式分为四种,一般我们不设置时默认为bridge单桥模式,容器使用独立的networkNamespace,并连接到docker0虚拟网卡中。通过docker0网桥以及Iptablesnat表配置与宿主机通信。  此时在堡垒机上进行测试,利用busybox进行测试:#拉取镜像dockerpullbusybox#运行容器dockerrun-itd–namebusy_bridgebusybox  指令dockernetworkinspect

    2022年8月21日
    13
  • vue动态生成表单_vue element 表单验证

    vue动态生成表单_vue element 表单验证前几天接了一个需求,需要动态生成一个表单数据,然后提交,提交完数据后。通过编辑按钮进入时,需要进行数据回填。没生成表单前的状态单机生成表单生成表单根据选择方式展示不同的表单元素如果从编辑页进入该页面有数据的话,进行数据回填样式同第三点相似,这里不再说明思路:请输入标题,请选择类型为父组件;请选择方式为子组件;根据请选择方式出来的内容为孙子组件难…

    2025年6月11日
    3
  • rider 激活码分享【中文破解版】

    (rider 激活码分享)好多小伙伴总是说激活码老是失效,太麻烦,关注/收藏全栈君太难教程,2021永久激活的方法等着你。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.htmlS32PGH0SQB-eyJsaWNlbnNlSWQi…

    2022年3月25日
    382

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号