设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间21 现在时间21 缓存数据 青春之所以让人留念,是因为我们年轻时干的蠢事大都妙不可言。晚安!

青春之所以让人留念,是因为我们年轻时干的蠢事大都妙不可言。晚安!

查看: 1452|回复: 2

如何在.Net6 web api中记录每次接口请求的日志

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:205
  • 打卡月天数:0
  • 打卡总奖励:3160
  • 最近打卡:2023-08-27 06:04:43
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
428
主题
385
精华
0
金钱
4402
积分
841
注册时间
2022-12-21
最后登录
2025-3-13

发表于 2023-7-20 02:58:34 | 显示全部楼层 |阅读模式

为什么在软件设计中一定要有日志系统?

在软件设计中日志模块是必不可少的一部分,可以帮助开发人员更好的了解程序的运行情况,提高软件的可靠性,安全性和性能,日志通常能帮我们解决如下问题:

  • 调试和故障排查:日志可以记录程序运行时的各种信息,包括错误,异常,警告等,方便开发人员在出现问题时进行调试和故障排查。
  • 性能优化:日志可以记录程序的运行时间,资源占用等信息,帮助开发人员进行性能优化。
  • 安全审计:日志可以记录用户的操作行为,方便进行安全审计和追踪。
  • 统计分析:日志可以记录用户的访问情况,使用习惯等信息,方便进行统计分析和用户行为研究。
  • 业务监控:日志可以记录业务数据的变化情况,方便进行业务监控和数据分析。
  • 数据还原:日志记录每次请求的请求及响应数据,可以在数据丢失的情况下还原数据。

如何在.net6webapi中添加日志?

1.添加日志组件

.net6有自带的logging组件,还有很多优秀的开源log组件,如NLog,serilog,这里我们使用serilog组件来构建日志模块。

新建.net6,asp net web api项目之后,为其添加如下四个包

040010ra6w0ahw058nv59m.png

  1. dotnet add package Serilog.AspNetCore//核心包
  2. dotnet add package Serilog.Formatting.Compact
  3. dotnet add Serilog.Sinks.File//提供记录到文件
  4. dotnet add Serilog.Sinks.MSSqlServer//提供记录到sqlserver
复制代码

2.新建SeriLogExtend扩展类型,配置日志格式并注入

  1. public static class SeriLogExtend
  2. {
  3. public static void AddSerilLog(this ConfigureHostBuilder configureHostBuilder)
  4. {
  5. //输出模板
  6. string outputTemplate = "{NewLine}【{Level:u3}】{Timestamp:yyyy-MM-dd HH:mm:ss.fff}" +
  7. "{NewLine}#Msg#{Message:lj}" +
  8. "{NewLine}#Pro #{Properties:j}" +
  9. "{NewLine}#Exc#{Exception}" +
  10. new string('-', 50);
  11. // 配置Serilog
  12. Log.Logger = new LoggerConfiguration()
  13. .MinimumLevel.Override("Microsoft", LogEventLevel.Warning) // 排除Microsoft的日志
  14. .Enrich.FromLogContext() // 注册日志上下文
  15. .WriteTo.Console(outputTemplate: outputTemplate) // 输出到控制台
  16. .WriteTo.MSSqlServer("Server=.;Database=testdb;User ID=sa;Password=123;TrustServerCertificate=true", sinkOptions: GetSqlServerSinkOptions(), columnOptions: GetColumnOptions())
  17. .WriteTo.Logger(configure => configure // 输出到文件
  18. .MinimumLevel.Debug()
  19. .WriteTo.File( //单个日志文件,总日志,所有日志存到这里面
  20. $"logs\\log.txt",
  21. rollingInterval: RollingInterval.Day,
  22. outputTemplate: outputTemplate)
  23. .WriteTo.File( //每天生成一个新的日志,按天来存日志
  24. "logs\\{Date}-log.txt", //定输出到滚动日志文件中,每天会创建一个新的日志,按天来存日志
  25. retainedFileCountLimit: 7,
  26. outputTemplate: outputTemplate
  27. ))
  28. .CreateLogger();
  29. configureHostBuilder.UseSerilog(Log.Logger); // 注册serilog
  30. /// <summary>
  31. /// 设置日志sqlserver配置
  32. /// </summary>
  33. /// <returns></returns>
  34. MSSqlServerSinkOptions GetSqlServerSinkOptions()
  35. {
  36. var sqlsinkotpions = new MSSqlServerSinkOptions();
  37. sqlsinkotpions.TableName = "sys_Serilog";//表名称
  38. sqlsinkotpions.SchemaName = "dbo";//数据库模式
  39. sqlsinkotpions.AutoCreateSqlTable = true;//是否自动创建表
  40. return sqlsinkotpions;
  41. }
  42. /// <summary>
  43. /// 设置日志sqlserver 列配置
  44. /// </summary>
  45. /// <returns></returns>
  46. ColumnOptions GetColumnOptions()
  47. {
  48. var customColumnOptions = new ColumnOptions();
  49. customColumnOptions.Store.Remove(StandardColumn.MessageTemplate);//删除多余的这两列
  50. customColumnOptions.Store.Remove(StandardColumn.Properties);
  51. var columlist = new List<SqlColumn>();
  52. columlist.Add(new SqlColumn("RequestJson", SqlDbType.NVarChar, true, 2000));//添加一列,用于记录请求参数string
  53. columlist.Add(new SqlColumn("ResponseJson", SqlDbType.NVarChar, true, 2000));//添加一列,用于记录响应数据
  54. customColumnOptions.AdditionalColumns = columlist;
  55. return customColumnOptions;
  56. }
  57. }
  58. }
复制代码

然后再program.cs中调用这个扩展方法

  1. var builder = WebApplication.CreateBuilder(args);
  2. // Add services to the container.
  3. builder.Services.AddControllers(options =>
  4. {
  5. options.Filters.Add(typeof(RequestLoggingFilter));
  6. });
  7. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
  8. builder.Services.AddEndpointsApiExplorer();
  9. builder.Services.AddSwaggerGen();
  10. builder.Host.AddSerilLog();
  11. var app = builder.Build();
  12. // Configure the HTTP request pipeline.
  13. if (app.Environment.IsDevelopment())
  14. {
  15. app.UseSwagger();
  16. app.UseSwaggerUI();
  17. }
  18. app.UseHttpsRedirection();
  19. app.UseAuthorization();
  20. app.MapControllers();
  21. app.Run();
复制代码

这里我设计的日志信息只包括了

  • Message:日志信息
  • Level:等级
  • TimeStamp:记录日志时间
  • Exception:异常信息
  • RequestJson:请求参数json
  • ResponseJson:响应结果json

其中前面四种为日志默认,后两种为我主动添加,在实际的设计中还有可能有不同的信息,如:

  • IP:请求日志
  • Action:请求方法
  • Token:请求token
  • User:请求的用户

日志的设计应该根据实际的情况而来,其应做到足够详尽,能帮助开发者定位,解决问题,而又不能过于重复臃肿,白白占用系统空间,我这边的示例仅供大家参考

3.添加RequestLoggingFilter过滤器,用以记录每次请求的日志

  1. public class RequestLoggingFilter : IActionFilter
  2. {
  3. private readonly Serilog.ILogger _logger;//注入serilog
  4. private Stopwatch _stopwatch;//统计程序耗时
  5. public RequestLoggingFilter(Serilog.ILogger logger)
  6. {
  7. _logger = logger;
  8. _stopwatch = Stopwatch.StartNew();
  9. }
  10. public void OnActionExecuted(ActionExecutedContext context)
  11. {
  12. _stopwatch.Stop();
  13. var request = context.HttpContext.Request;
  14. var response = context.HttpContext.Response;
  15. _logger
  16. .ForContext("RequestJson",request.QueryString)//请求字符串
  17. .ForContext("ResponseJson", JsonConvert.SerializeObject(context.Result))//响应数据json
  18. .Information("Request {Method} {Path} responded {StatusCode} in {Elapsed:0.0000} ms",//message
  19. request.Method,
  20. request.Path,
  21. response.StatusCode,
  22. _stopwatch.Elapsed.TotalMilliseconds);
  23. }
  24. public void OnActionExecuting(ActionExecutingContext context)
  25. {
  26. }
  27. }
复制代码

在program.cs中将该过滤器添加进所有控制器之中

  1. builder.Services.AddControllers(options =>
  2. {
  3. options.Filters.Add(typeof(RequestLoggingFilter));
  4. });
  5. // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
  6. builder.Services.AddEndpointsApiExplorer();
  7. builder.Services.AddSwaggerGen();
  8. builder.Host.AddSerilLog();
  9. var app = builder.Build();
  10. // Configure the HTTP request pipeline.
  11. if (app.Environment.IsDevelopment())
  12. {
  13. app.UseSwagger();
  14. app.UseSwaggerUI();
  15. }
  16. app.UseHttpsRedirection();
  17. app.UseAuthorization();
  18. app.MapControllers();
  19. app.Run();
复制代码

测试效果

在控制器添加一个测试方法并将其调用一次

  1. [HttpGet]
  2. public dynamic Get123(string model)
  3. {
  4. return new { name = "123", id = 2 };
  5. }
复制代码

040010x9bbph8hp91ag3oo.png

控制台输出

040011hdvmkaf0cg1yf1yy.png

数据库记录

040011aokooquomggq3f9w.png

项目根目录下logs文件夹中日志文件记录

040011kdjckjk82wk85ldc.png

到此这篇关于如何在.Net6 web api中记录每次接口请求的日志的文章就介绍到这了,更多相关.net记录每次接口请求的日志内容请搜索晓枫资讯以前的文章或继续浏览下面的相关文章希望大家以后多多支持晓枫资讯!


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
20
积分
20
注册时间
2022-12-25
最后登录
2022-12-25

发表于 2024-10-30 11:26:12 | 显示全部楼层
感谢楼主分享。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
11
积分
2
注册时间
2023-12-16
最后登录
2023-12-16

发表于 2025-4-23 00:23:51 | 显示全部楼层
路过,支持一下
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼
3楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表