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)


相关推荐

  • rwx权限详解

    rwx权限详解

  • opkg update失败问题解决

    opkg update失败问题解决执行opkgupdate提示找不文件。root@EC2022v:~/clienttest#opkgupdateDownloadinghttp://downloads.openwrt.org/barrier_breaker/14.07/at91/generic/packages/base/Packages.gz.wget:serverreturnederror:HTTP/1.0…

  • [转]深邃之思想,纯粹之灵魂——我所了解的柳智宇学长

    [转]深邃之思想,纯粹之灵魂——我所了解的柳智宇学长https://zhuanlan.zhihu.com/p/32340797柳智宇学长文集前言部分深邃之思想,纯粹之灵魂——我所了解的柳智宇学长——2017年12月25日中国.湖北.武汉.华中科技大学【陆秋宇】正文部分读到自己高二写的这篇文章——2005年中国.湖北.武汉.华中师大一附中远慰风雨夕——2006年7月斯洛文尼亚.卢布尔雅那.第47届IMO前夜我在大学的成长历程…

  • java static关键字的作用_java中static关键字的作用是什么

    java static关键字的作用_java中static关键字的作用是什么java中static关键字的作用:1、java中可以通过statin关键字修饰变量达到全局变量的效果;2、static修饰的方法属于类方法,不需要创建对象就可以调用;3、static代码块常用于初始化静态变量。本文操作环境:windows10系统、java1.8、thinkpadt480电脑。java中static关键字的作用:在java语言中有四种使用情况:成员变量、成员方法、代码块和内部…

  • layui弹框传值_LAYUI弹出层详解

    layui弹框传值_LAYUI弹出层详解还是一步步展示把首先,layer可以独立使用,也可以通过Layui模块化使用。我个人一直是用的模块化的所以下面素有的都是基于模块化的。引入好相关文件就可以开始啦今天放图片把试着学一下放图片1.最简单的弹层,这个弹层的效果其实就是一个加了特效和样式的alert();代码如下:layui.use(“layer”,function(){varlayer=layui.layer;la…

  • Windows 7系统安装MySQL5.5.21图解

    Windows 7系统安装MySQL5.5.21图解

    2021年11月16日

发表回复

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

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