|
|
目录' G/ l8 A2 H) x
7 i1 t) J! l; Y' p1 u# A0 z( n9 Q& l/ m- A: `7 `8 u1 L9 Q! J
- 一、开启服务端请求日志, c1 ^# P- b c6 P" c1 ?$ ?
- 二、开启客户端请求日志0 l6 l* Z) J& H. F+ ]- t2 }* W
- 三、示例
5 D% s1 L8 V( P3 r- \1 _' r# B 最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据。Xfrogcn.AspNetCore.Extensions扩展库提供了服务端和客户端的详细日志功能,通过配置可以开启。
' m3 F6 a, d- {9 ^: M2 d# d 服务端日志通过请求中间件来完成,中间件会以Trace级别记录请求和应答详情,以Debug级别记录请求耗时。服务的请求日志的名称为ServerRequest.Logger
, [6 _$ w. w: F7 L 要开启服务端详情日志,只需将扩展库配置中的ServerRequestLevel属性设置为Verbose级别,该配置默认是Information,故不会记录请求详情及请求耗时。
# _5 J7 B3 } i' l5 j+ L 开启请求详情后,由于需要读取请求和应答的详细内容,对性能将有所影响。同时,由于要读取请求体,将自动开启请求的缓冲。只有在需要记录详细日志时,才会读取详情,故关闭后对于性能不会产生太大影响。
3 o6 B* p2 v- l+ ?+ i 客服端的请求详细日志,是基于IHttpClientFactory以及HttpClient框架,在客户端请求管道处理中加入了日志记录管道。请求处理管道会以Trace级别记录请求和应答详情,另外,如果请求发生异常,将以Error级别记录异常详情。客户端请求日志的名称为ClientRequest.Logger
. d$ D! U" R6 m; k& ]( a, M3 P 要开启客户端请求详细日志,只需将扩展库配置中的EnableClientRequestLog设置为true,同时将ClientRequestLevel设置为Verbose,该设置的默认值为Information。与服务端一样,只有在符合条件时才会记录请求与应答详情,故如果未开启,对性能不会产生影响。注意,当EnableClientRequestLog设置为false时,扩展库不会将日志请求管道插入客户端请求管道中。该设置默认为true。 s% x+ _! `. l, U0 R
4 S7 B' a8 r" O. e& F一、开启服务端请求日志
9 y3 T0 T, b- n, y) ~, C2 \
8 O, m- F$ T- ?8 a7 E+ ?$ v
; V/ |$ t2 W- V5 T% l7 a 要在服务端开启请求详细日志,只需引用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(); }
复制代码 二、开启客户端请求日志4 g0 L |; G( D6 T$ k
) G( G P* v# B( p* v1 p
/ ~% t$ ^( o: e- t- o m) S# v+ g
要开启客户端日志,只需引用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(); HttpClient client = clientFactory.CreateClient(); var response = await client.GetAsync("http://localhost:5000/weatherforecast"); Console.ReadLine(); } }
复制代码 三、示例 n. {/ n( t& Y h
+ C6 k3 F/ t0 T9 I- G
: K" l+ U' T9 i2 ^* H4 L3 f
详细示例请参考GitHub; s" C& @) G6 ?) a3 b
Xfrogcn.AspNetCore.Extensions地址:GitHub Gitee( Z$ r& {! O8 @( h
以上就是ASP.NET Core扩展库之Http日志的使用详解的详细内容,更多关于ASP.NET Core扩展库之Http日志的资料请关注脚本之家其它相关文章!
6 R$ N) X0 s- B& v: u( i! Z
m1 H2 y% H$ V$ F% ` K2 E4 n+ [* {来源:http://www.jb51.net/article/209479.htm
0 G; |+ c( f+ ^( a s4 a8 F免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
|