最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据。Xfrogcn.AspNetCore.Extensions扩展库提供了服务端和客户端的详细日志功能,通过配置可以开启。

服务端日志通过请求中间件来完成,中间件会以Trace级别记录请求和应答详情,以Debug级别记录请求耗时。服务的请求日志的名称为ServerRequest.Logger

要开启服务端详情日志,只需将扩展库配置中的ServerRequestLevel属性设置为Verbose级别,该配置默认是Information,故不会记录请求详情及请求耗时。

开启请求详情后,由于需要读取请求和应答的详细内容,对性能将有所影响。同时,由于要读取请求体,将自动开启请求的缓冲。只有在需要记录详细日志时,才会读取详情,故关闭后对于性能不会产生太大影响。

客服端的请求详细日志,是基于IHttpClientFactory以及HttpClient框架,在客户端请求管道处理中加入了日志记录管道。请求处理管道会以Trace级别记录请求和应答详情,另外,如果请求发生异常,将以Error级别记录异常详情。客户端请求日志的名称为ClientRequest.Logger

要开启客户端请求详细日志,只需将扩展库配置中的EnableClientRequestLog设置为true,同时将ClientRequestLevel设置为Verbose,该设置的默认值为Information。与服务端一样,只有在符合条件时才会记录请求与应答详情,故如果未开启,对性能不会产生影响。注意,当EnableClientRequestLog设置为false时,扩展库不会将日志请求管道插入客户端请求管道中。该设置默认为true。

一、开启服务端请求日志

要在服务端开启请求详细日志,只需引用Xfrogcn.AspNetCore.Extensions库,然后在Startup类中,配置服务请求级别为Verbose:

    public void ConfigureServices(IServiceCollection services)
{
services.AddExtensions(Configuration, config=>
{
config.FileLog = true;
config.ConsoleLog = true;
// 设置服务端请求日志级别为Verbose
config.ServerRequestLevel = Serilog.Events.LogEventLevel.Verbose;
});
services.AddControllers();
}

二、开启客户端请求日志

要开启客户端日志,只需引用Xfrogcn.AspNetCore.Extensions库,然后在Startup类中,配置ClientRequestLevel为Verbose, EnableClientRequestLog设置为true。

    class Program
{
static async Task Main(string[] args)
{
IServiceCollection services = new ServiceCollection()
.AddExtensions(null, config =>
{
config.EnableClientRequestLog = true;
config.ClientRequestLevel = Serilog.Events.LogEventLevel.Verbose;
config.ConsoleLog = true;
}); IServiceProvider provider = services.BuildServiceProvider();
var clientFactory = provider.GetRequiredService<IHttpClientFactory>();
HttpClient client = clientFactory.CreateClient(); var response = await client.GetAsync("http://localhost:5000/weatherforecast"); Console.ReadLine();
}
}

三、示例

详细示例请参考GitHub

Xfrogcn.AspNetCore.Extensions地址:GitHub Gitee

最新文章

  1. DataTable数据检索的性能分析(转寒江独钓)
  2. MaxScale:实现MySQL读写分离与负载均衡的中间件利器
  3. js隐藏或显示某区域
  4. Android开发之SlidingMenu开源项目的使用和问题
  5. Httpsqs的安装以及安装过程错误的解决方法 转
  6. 使用XHTML+CSS构架的好处到底有哪些?
  7. 三. ServerSocket用法
  8. ECshop 二次开发模板教程3
  9. Simple Membership 学习笔记
  10. sudo 和 sudoers设置
  11. linux if 判断字符串是否相等
  12. Constructor Prototype Pattern 原型模式(PHP示例)
  13. python的正则表达式 re
  14. 没事不要在for循环期间增减迭代序列的成员
  15. 业务线B/C端业务组件总结
  16. input file实现多选和限制文件上传类型
  17. June 8. 2018 Week Week 23rd Friday
  18. Python 爬58同城 城市租房信息
  19. linux find命令用法
  20. C# 用Linq查询DataGridView行中的数据是否包含(各种操作)

热门文章

  1. JS Calendar API
  2. Event Bus &amp; Event Emitter
  3. 「NGK每日快讯」2021.1.8日NGK第66期官方快讯!
  4. Python学习笔记_爬虫数据存储为xlsx格式的方法
  5. Python安装教程
  6. 1022 Digital Library——PAT甲级真题
  7. spring-ioc注解-理解2 零配置文件
  8. 2021-2-28:调用 System.gc() 后究竟发生了什么?
  9. 学习java的第二天
  10. Ch1-What is DAX?