码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Nlog 集成到WebApi


    前言

    之前的这篇文章中介绍了,桌面程序是如何使用Nlog的

    Nlog 的使用_code bean的博客-CSDN博客_nlog使用${appdomain}当前应用程序域l${assembly-version}应用程序${basedir}应用程序域的基本目录。${callsite}(类名称、方法名称和相关信息的源信息)。${counter}数值${date}当前日期和时间。${environment}环境变量${exception}exception信息${guid}GUID${identity}线程标识信息${level}级别。${log4jx..https://blog.csdn.net/songhuangong123/article/details/124152443?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522166756627816782427448356%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=166756627816782427448356&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~blog~first_rank_ecpm_v1~rank_v31_ecpm-1-124152443-null-null.article_score_rank_blog&utm_term=Nlog&spm=1018.2226.3001.4450#:~:text=%E5%8F%91%E5%B8%83-,Nlog%20%E7%9A%84%E4%BD%BF%E7%94%A8,-code%20bean

    但是如果是WebApi,有一点不同,总的来说,前期的配置工作变多了。其他的不变。

    安装

    首先是安装包:建议5以上版本

    nlog.config 

    然后准备一个nlog.config文件

    和之前的差不多,稍微更改一下:

    1. "1.0" encoding="utf-8" ?>
    2. <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd"
    3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    4. autoReload="true"
    5. throwExceptions="true"
    6. internalLogLevel="Off"
    7. internalLogFile="Logs\internal-nlog-AspNetCore.txt">
    8. <targets>
    9. <target name="console" xsi:type="ColoredConsole" layout="${date:format=HH\:MM\:ss} ${logger} ${message}"/>
    10. <target name="debug_file"
    11. xsi:type="File"
    12. fileName="${basedir}/Logs/${shortdate}/Debug/log.txt"
    13. maxArchiveFiles="30"
    14. layout="【${longdate}】${level:uppercase=false} ${callsite:className=True:fileName=True:includeSourcePath=False:methodName=False}:${message}" />
    15. <target name="error_file"
    16. xsi:type="File"
    17. fileName="${basedir}/Logs/${shortdate}/log.txt"
    18. maxArchiveFiles="30"
    19. layout="【${longdate}】${level:uppercase=false} ${callsite:className=True:fileName=True:includeSourcePath=False:methodName=False}:${message}" />
    20. targets>
    21. <rules>
    22. <logger name="System.*" finalMinLevel="Warn"/>
    23. <logger name="Microsoft.*" finalMinLevel="Warn"/>
    24. <logger name="Microsoft.Hosting.Lifetime*" finalMinLevel="Info"/>
    25. <logger name="*" minlevel="Trace" writeTo="console" />
    26. <logger name="*" minlevel="Debug" writeTo="debug_file" />
    27. <logger name="*" minlevel="Error" writeTo="error_file" />
    28. rules>
    29. nlog>

    对Config的简单说明

    autoReload="true"
    在配置文件头部的这个属性,如果有True,在网站跑的过程中,可以随时变更nlog.config文件,随时生效。

    throwExceptions="true"
    这个前期对nlog.config文件如果有写法错误,或是项目中对日志模块有什么异常错误的话,会主动抛出来,这个对前期集成NLog模块或写配置文件时有用。

    1. <logger name="System.*" finalMinLevel="Warn"/>
    2. <logger name="Microsoft.*" finalMinLevel="Warn"/>
    3. <logger name="Microsoft.Hosting.Lifetime*" finalMinLevel="Info"/>

    这个主要是过滤掉一些WebApi内部的一些打印信息,不然你的打印会带出来其他的一堆打印。但是程序启动的WebApi的一些内容,目前我发现过滤不掉。不过之后就没有了。

    修改Program.cs

    最关键的一句话

    builder.Logging.AddNLog("nlog.config");

    Program.cs中加入这句

    这就相当于注册,为注入做准备,不然控制器里的_logger也无法输出log到文件

    注入之后,控制器里直接用就好了:

    控制器使用情况

    Program.cs的全部内容如下:

    1. using MySocketLib.TcpSvr;
    2. using NLog;
    3. using NLog.Web;
    4. var logger = NLog.LogManager.Setup().LoadConfigurationFromAppSettings().GetCurrentClassLogger();
    5. logger.Debug("init main");
    6. try
    7. {
    8. var builder = WebApplication.CreateBuilder(args);
    9. // Add services to the container.
    10. builder.Services.AddControllers();
    11. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
    12. builder.Services.AddEndpointsApiExplorer();
    13. builder.Services.AddSwaggerGen();
    14. //为了返回任意形式xml,需要这个,需要安装包:Microsoft.AspNetCore.Mvc.WebApiCompatShim
    15. builder.Services.AddMvc().AddWebApiConventions();
    16. builder.Logging.AddNLog("nlog.config");
    17. var app = builder.Build();
    18. // Configure the HTTP request pipeline.
    19. if (app.Environment.IsDevelopment())
    20. {
    21. app.UseSwagger();
    22. app.UseSwaggerUI();
    23. }
    24. app.UseAuthorization();
    25. app.MapControllers();
    26. //启动TCP
    27. TcpSvrCtrl.Run();
    28. app.Run();
    29. }
    30. catch (Exception exception)
    31. {
    32. // NLog: catch setup errors
    33. logger.Error(exception, "Stopped program because of exception");
    34. throw;
    35. }
    36. finally
    37. {
    38. // Ensure to flush and stop internal timers/threads before application-exit (Avoid segmentation fault on Linux)
    39. NLog.LogManager.Shutdown();
    40. }

  • 相关阅读:
    开咖啡店需要注意什么?知名咖啡店总结五点
    【无标题】
    郝斌 数据结构源代码和数据结构 大纲源代码
    数学基础(五)最优化理论(最优化,无约束,有约束,拉格朗日乘子的意义,KKT条件)
    maven安装配置
    21.4 Python 使用GeoIP2地图定位
    【postgresql初级使用】updatable view 可修改的视图,以及视图数据致性的控制,完全分离数据报表业务与数据的维护操作部署架构尝试
    SQLserver基础入门理论(超基础)完
    SQL server数据库单用户模式如何退出
    滑块视图的实现
  • 原文地址:https://blog.csdn.net/songhuangong123/article/details/127696195
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号