首页 > 其他分享 >.NET Core 6.0 log4Net 日志配置

.NET Core 6.0 log4Net 日志配置

时间:2023-07-28 22:11:06浏览次数:62  
标签:log4Net Core log4net -- result 6.0 日志 logger user

1、 安装Microsoft.Extensions.Logging.Log4Net.AspNetCore 包

2、 创建日志配置文件log4net.config ,并设置文件属性为始终复制

可以去官网下载配置文件, Apache log4net – Apache log4net: Config Example - Apache log4net

<?xml version="1.0" encoding="utf-8" ?>
<log4net>
    <!-- Define some output appenders -->

    <!--Type 表示用那种类型记录日志-->
    <appender name="rollingAppender" type="log4net.Appender.RollingFileAppender">
        <!--表示用文本来记录日志-->

        <file value="log\log.txt" />
        <!--<file value="D:\MyLog1\Onelog.txt" />-->

        <!--追加日志内容-->
        <!--<appendToFile value="false" />-->
        <appendToFile value="true" />

        <!--防止多线程时不能写Log,官方说线程非安全-->
        <lockingModel type="log4net.Appender.FileAppender+MinimalLock" />
        <!--最小锁-->

        <!--配置Unicode编码-->
        <Encoding value="UTF-8" />

        <!--是否只写到一个文件里-->
        <param name="StaticLogFileName" value="false" />

        <!--当备份文件时,为文件名加的后缀,这里可以作为每一天的日志分别存储不同的文件-->
        <datePattern value="yyyyMMdd&quot;.txt&quot;" />

        <!--可以为:Once|Size|Date|Composite-->
        <!--Composite为Size和Date的组合-->
        <!--<rollingStyle value="Composite" />-->
        <rollingStyle value="Size" />

        <!--日志最大个数,都是最新的-->
        <!--rollingStyle节点为Size时,只能有value个日志文件-->
        <!--rollingStyle节点为Composite时,每天有value个日志-->
        <maxSizeRollBackups value="2" />

        <!--可用的单位:KB|MB|GB-->
        <maximumFileSize value="2MB" />

        <!--置为true,当前最新日志文件名永远为file节中的名字-->
        <staticLogFileName value="true" />

        <!--过滤器-->

        <!--阻止所有事件被记录-->
        <!--<filter type="log4net.Filter.DenyAllFilter"> </filter>-->

        <!--只有指定等级的日志事件才被记录-->
        <!--<filter type="log4net.Filter.LevelMatchFilter">
        <param value="FATAL" />
      </filter>-->

        <!--日志等级在指定范围内的事件才被记录-->
        <!--<filter type="log4net.Filter.LevelRangeFilter">
        <param name="LevelMin" value="ERROR" />
        <param name="LevelMax" value="FATAL" />
      </filter>-->


        <layout type="log4net.Layout.PatternLayout">
            <!--日志输出格式:时间  日志类型  日志内容-->
            <conversionPattern value="%date [%thread] %-5level %logger - %message%newline"/>
        </layout>
    </appender>

    <!-- levels: OFF > FATAL > ERROR > WARN > INFO > DEBUG  > ALL -->
    <root>
        <priority value="ALL"/>
        <level value="ALL"/>
        <appender-ref ref="rollingAppender" />
    </root>
</log4net>

 

3、 在Program.cs 文件注入log4Net服务

A、 若日志配置文件log4Net.config放在项目根路径下,就能默认读取。

//注入Log4Net服务
builder.Logging.AddLog4Net();

B、 若日志配置文件log4net.config放不是根路径下,就得在AddLog4Net()后面写上路径

//注入Log4Net服务
builder.Logging.AddLog4Net(”Config/log4net.config“);

 

4、 通过构造函数注入,使用Log4Net

public readonly ILogger<LoginController> _logger;
public LoginController(IUserService userService,ILogger<LoginController> logger) 
{ _userservice= userService; _logger = logger; } [HttpGet] public async Task<IActionResult> UserLogin([FromQuery]LoginModel model) { User user = new User(); user.Badge = model.Badge; user.Password = model.Password; var result = await _userservice.Login(user.Badge,user.Password); if (result != null) { _logger.LogInformation($"{result.Badge}-{result.CName}在{DateTime.Now.ToString("yyyy-dd-MM HH:mm:ss ")}登入了IPSP系统!"); } return Ok(result); }

 

5、查看日志,打开项目根目录在bin/debug/net6.0目录下可以看到log文件夹,里面有个log.txt文件

 

标签:log4Net,Core,log4net,--,result,6.0,日志,logger,user
From: https://www.cnblogs.com/xjxue/p/17589013.html

相关文章

  • [回馈]ASP.NET Core MVC开发实战之商城系统(三)
    经过一段时间的准备,新的一期【ASP.NETCoreMVC开发实战之商城系统】已经开始,在之前的文章中,讲解了商城系统的整体功能设计,页面布局设计,环境搭建,系统配置,及首页【商品类型,banner条,友情链接,降价促销,新品爆款】等功能的开发,今天继续讲解商品列表页面功能开发,仅供学习分享使用,如有不......
  • 通过 Javacore 诊断线程挂起等性能问题
    Javacore与WebSphereCommerce性能问题近年来,依据WebSphereCommerce(以下简称为WC)搭建的电子商务网站系统日益增多。由于系统本身的复杂性,一旦系统出现问题,尤其是性能问题,问题诊断和定位就会非常困难。下图所示为由WC系统为核心搭建的电子商务网站的一般逻辑架构,如图......
  • Asp.Net Core 集成JWT采用Rsa非对称密钥并实现自定义身份验证
    授权和鉴权分为了两个项目。首先是授权:建立Asp.netcore项目,并在Nuget包安装System.IdentityModel.Tokens.Jwt新建一个WebApi用于登录,这里使用账户密码方便调试。另外BaseResult是我封装的一个统一返回数据类型。需要注意的是audience以及JwtRegisteredClaimNames.Name......
  • .NET Core 验证码 - LazyCaptcha
    1.前言    在开发网站登录,安全验证等方面的时候,我们经常会使用到验证码,以前我们制作验证码的时候,一般都会写大量的代码完成验证码的制作。有没有现成,又好用的验证码工具插件呢?当然是有的,这里就介绍一个开源又好用的验证码工具LazyCaptcha。2.LazyCaptcha介绍   ......
  • C# 扫描并读取图片中的文字(.NET Core)
    本文介绍如何通过C#程序来扫描并读取图片中的文字,这里以创建一个.NetCore程序为例。下面是具体步骤,供参考。程序测试环境:VisualStudio版本要求不低于2017图片扫描工具:Spire.OCRfor.NET图片格式:png(这里的图片格式支持JPG、PNG、GIF、BMP、TIFF等格式)扫描的图片文字:中文(......
  • 【HMS Core】统一扫描连续扫码、闪光灯关闭问题
    ​ 【问题描述1】使用DefaultViewMode进行扫码,如何实现连续扫码 【解决方案】在默认扫码模式DefaultView中,功能是集成在SDK内部的,无法设置连续扫码模式等信息。可以使用CustomizedViewMode这种模式,它提供了相关的api可以设置是否连续扫码:通过setContinuouslyScan方法......
  • rdma-core之rdma_client.c
    库函数、全局变量#include<stdio.h>#include<stdlib.h>#include<string.h>#include<netdb.h>#include<errno.h>#include<getopt.h>#include<rdma/rdma_cma.h>#include<rdma/rdma_verbs.h>staticconstchar*server......
  • ubuntu22 redis 6.0.16
    一、安装下载安装更新软件库aptupdate下载安装sudoaptinstallredis-server-y查看是否运行sudosystemctlstatusredis-serverActive:active(running)sinceFri2023-05-1912:56:25CST;3min19sago测试redis-cli127.0.0.1:6379>keys*(emptyarray)exit二、配置配......
  • Zabbix Server 6.0 LTS 原生高可用HA集群部署 - On Debian11
    官方文档里面说明,ZabbixServerHA最少需要两个节点,多台Zabbixserver作为集群中的节点运行。当集群中的一个Zabbixserver处于active时,其他服务器处于standy,随时准备在必要时接管。无论集群的节点数量有多少,只有一个节点实例是出于Active状态,Standby节点不收集监控数据或者......
  • NET7下EFCORE的通用增删查改类
    NET7下EFCORE的通用增删查改类代码摘录自《深入浅出ASP.NETCORE》 ///<summary>///所有仓储的约定,此接口仅作为约定,用于标识他们///</summary>///<typeparamname="TEntity">传入仓储的实体模型</typeparam>///<typeparamname="TPrimaryKey&quo......