京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 7213|回复: 0

ASP.NET Core扩展库之Http日志的使用详解

[复制链接]

25

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2021-7-25 20:47:44 | 显示全部楼层 |阅读模式 来自 中国
目录# f& y3 G. o. I' Z0 N0 P

1 q; w6 H2 T- ?

    # q8 K1 B$ X3 R" z8 J3 j2 _. W. m
  • 一、开启服务端请求日志
    " q, _. c" l2 [$ D7 A- m
  • 二、开启客户端请求日志& G* k( B1 F% Y$ V  b; O3 O
  • 三、示例8 A! A  N  d( ?4 s
    最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据。Xfrogcn.AspNetCore.Extensions扩展库提供了服务端和客户端的详细日志功能,通过配置可以开启。6 m8 w# G& }3 d4 U9 C) Y" d9 u
    服务端日志通过请求中间件来完成,中间件会以Trace级别记录请求和应答详情,以Debug级别记录请求耗时。服务的请求日志的名称为ServerRequest.Logger
* h( \' O% g8 Z0 h# R- ~$ n" l! A' ~    要开启服务端详情日志,只需将扩展库配置中的ServerRequestLevel属性设置为Verbose级别,该配置默认是Information,故不会记录请求详情及请求耗时。$ V9 R9 y+ |0 _8 Z7 M' A8 U
    开启请求详情后,由于需要读取请求和应答的详细内容,对性能将有所影响。同时,由于要读取请求体,将自动开启请求的缓冲。只有在需要记录详细日志时,才会读取详情,故关闭后对于性能不会产生太大影响。
6 Z: P3 p9 y- n* V0 X    客服端的请求详细日志,是基于IHttpClientFactory以及HttpClient框架,在客户端请求管道处理中加入了日志记录管道。请求处理管道会以Trace级别记录请求和应答详情,另外,如果请求发生异常,将以Error级别记录异常详情。客户端请求日志的名称为ClientRequest.Logger& p2 P- H5 u$ W$ e
    要开启客户端请求详细日志,只需将扩展库配置中的EnableClientRequestLog设置为true,同时将ClientRequestLevel设置为Verbose,该设置的默认值为Information。与服务端一样,只有在符合条件时才会记录请求与应答详情,故如果未开启,对性能不会产生影响。注意,当EnableClientRequestLog设置为false时,扩展库不会将日志请求管道插入客户端请求管道中。该设置默认为true。2 h1 _* h; s* |6 a& |- o2 o% Q. R

5 m$ n. w  v( e' x! l一、开启服务端请求日志
/ w6 U* R0 w6 `( U5 M# e' g$ G$ K

/ g3 c" }* \6 Z) s/ I/ O$ K' J
. C% p6 v( v9 F* A+ |2 F    要在服务端开启请求详细日志,只需引用Xfrogcn.AspNetCore.Extensions库,然后在Startup类中,配置服务请求级别为Verbose:
  1. public void ConfigureServices(IServiceCollection services)    {        services.AddExtensions(Configuration, config=>        {            config.FileLog = true;            config.ConsoleLog = true;            // 设置服务端请求日志级别为Verbose            config.ServerRequestLevel = Serilog.Events.LogEventLevel.Verbose;        });        services.AddControllers();    }
复制代码
二、开启客户端请求日志
5 j6 R4 g& I" V! F/ e7 s2 ~

3 X6 V3 ~6 N% r! s+ G- d6 D- T" p% k4 \) V; Q! \. {$ _
    要开启客户端日志,只需引用Xfrogcn.AspNetCore.Extensions库,然后在Startup类中,配置ClientRequestLevel为Verbose, EnableClientRequestLog设置为true。
  1. 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();            HttpClient client = clientFactory.CreateClient();            var response = await client.GetAsync("http://localhost:5000/weatherforecast");            Console.ReadLine();        }    }
复制代码
三、示例
/ o, B( w! l! ?0 n# _: X
0 s: r& l1 f" c# {! k( q
! Z, z+ Q& O; J$ I1 D' T* \% Y
    详细示例请参考GitHub$ \* {4 Y  I& {& H5 z( l) x
    Xfrogcn.AspNetCore.Extensions地址:GitHub Gitee
, ?  a8 F# f0 O以上就是ASP.NET Core扩展库之Http日志的使用详解的详细内容,更多关于ASP.NET Core扩展库之Http日志的资料请关注脚本之家其它相关文章!* x6 [& D$ C- W% x+ k9 ]8 s" v

$ W( o3 @; ^. \# |# G: z. Q来源:http://www.jb51.net/article/209479.htm
3 s7 A2 B2 Q2 ~9 G5 |3 }6 Y* d免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-10-29 19:53 , Processed in 0.045212 second(s), 22 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

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