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();

        }

 

    }

}

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 常见的十大物联网操作系统介绍(物联网开发技术)

    随着物联网产业的迅猛发展,物联网设备的种类和数量也随之快速增长。据Gartner预测,到2020年全球物联网设备将超过260亿个,物联网市场规模将达到1.9万亿美元。与传统的IT领域不一样,物联网设备分布在各个不同领域,功能和形态各不相同,这对物联网提出了巨大的挑战。嵌入式系统成为关键因素物联网依靠互联网完成信息的传递,嵌入式系统的加入使得信息传递更具有专用性。在物联网出现…

  • 安卓服务(Service)的两种开启方式以及服务的生命周期

    安卓服务(Service)的两种开启方式以及服务的生命周期

  • vim打开文件时提示E325[通俗易懂]

    vim打开文件时提示E325[通俗易懂]vim打开文件时,它提示E3225:ATTENTION

  • python sqrt函数的使用

    python sqrt函数的使用摘自《python程序设计基础》蔡永铭主编工具:python3.764-bit官方链接:https://www.python.org/平台:Windows10sqrt函数的使用sqrt中文名:平方根在python中使用函数之前需要了解一下模块的含义。模块是一个包含所有定义的函数和变量的文件,模块可以被别的程序引入,以使用该模块中的函数等功能。因为sqrt函数在math模块中,所…

  • 6688常见问题FAQ

    6688常见问题FAQ1、V-KLAY问题2、关于备份3、关于驱动问题、联机问题4、有关打补丁,刷机,升级5、JAVA使用问题6、解锁问题7、无网络问题8、铃声问题9、重要记事问题10、时间调整、自动开关机问题11、通讯录丢失问题12、wap上网13、有关工模(工程模式)6688常见问题FAQ:本帖最后由胡同印象于2006-10-2711:23编辑原文网址:http://bbs.0110.cn/threa

  • Linux | awk 命令「建议收藏」

    Linux | awk 命令「建议收藏」awk命令简介awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得非常强大,awk其实是一门语言,”格式扫描和处理语言“,它允许您创建

发表回复

您的电子邮箱地址不会被公开。

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