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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IDEA设置背景为自定义照片「建议收藏」

    IDEA设置背景为自定义照片「建议收藏」一分钟教你把女朋友的照片设置成IDEA的背景图片【建议收藏】1.为什么写这篇文章?2.操作方法2.1.步骤12.2.步骤22.3.快捷操作一2.4.快捷操作二1.为什么写这篇文章?事情是这样的,在2021年6月10日早上我在CSDN上发布了文章《你真的懂Java怎么输出HelloWorld吗?》。这篇文章就如同标题一样,讲的是Java输出HelloWorld时源码的实现原理,本身再正常不过的一篇文章,但没想到的是。。十几天过去了,我却收到如下的评论??!!大家居然对我的IDEA背

    2022年6月15日
    53
  • html跳转网页代码_js访问url

    html跳转网页代码_js访问urlJS判断搜索引擎来路跳转代码:varregexp=/\.(sogou|soso|baidu|google|youdao|yahoo|bing|118114|biso|gougou|ifeng|ivc|sooule|niuhu|biso)(\.[a-z0-9\-]+){1,2}\//ig;varwhere=document.referrer;if(regexp.test(where)){

    2022年8月12日
    8
  • 你了解System.out.println()的真正含义吗?

    你了解System.out.println()的真正含义吗?在Java编程中,我们常常用 System.out.println(); 来输出字符串,也许我们都已经猜到println()是方法名,但System是什么,out又是什么呢?  其实System是java.lang里面的一个类,如下图:     而out就是System里面的一个静态数据成员,而且这个成员是java.io.PrintStream类的引用。如下图,被关键字static修饰的成员可…

    2025年7月24日
    3
  • msfconsole安装命令_msfconsole实战

    msfconsole安装命令_msfconsole实战使用curlhttps://raw.githubusercontent.com/rapid7/metasploit-omnibus/master/config/templates/metasploit-framework-wrappers/msfupdate.erb>msfinstall&&\chmod755msfinstall&&\./msfinstall安

    2025年9月23日
    4
  • 无刷直流电机simulink模型(ansoft电机仿真教程)

    这段时间刚开始接触Matlab中的Simulink仿真,我就结合自己的专业,利用Simulink进行了无刷直流电机的仿真,因为Simulink工具箱里面有很多可用的模块,所以建模过程变得非常简单。在Matlab界面中new->model之后,找到SimulinkLibraryBrowser,这里面有系统自带的很多模块,接下来我们就需要找到自己所需要的模块了,了解无刷直流电机的工作原理以后…

    2022年4月11日
    57
  • Burpsuite教程(一)Burpsuite 火狐谷歌浏览器抓包教程

    Burpsuite教程(一)Burpsuite 火狐谷歌浏览器抓包教程1.1Web抓包火狐抓包环境需求:火狐浏览器代理插件1.打开测试工具BurpSuite,默认工具拦截功能是开启的,颜色较深,我们点击取消拦截。下图取消拦截状态,数据包可以自由通过:2.按下图顺序点击选显卡来到代理设置3.可以看到默认的代理设置情况,本地代理地址:127.0.0.1,代理端口8080。如果前面没有勾选一定要选择勾选。工具代理设置完毕。4.证书安装,浏览器输输入http://burp/,点击图示位置下载证书5配置证书,打开浏览器并导入证书火狐浏览器开打开证

    2022年5月4日
    755

发表回复

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

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