欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2022-03-24 08:22:16
最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据。xfrogcn.aspnetcore.extensio...

    最佳实践都告诉我们不要记录请求的详细日志,因为这有安全问题,但在实际开发中,请求的详细内容对于快速定位问题却是非常重要的,有时也是系统的强力证据。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:

二、开启客户端请求日志

    要开启客户端日志,只需引用xfrogcn.aspnetcore.extensions库,然后在startup类中,配置clientrequestlevel为verbose, enableclientrequestlog设置为true。

三、示例

    详细示例请参考github

    xfrogcn.aspnetcore.extensions地址:github gitee

以上就是asp.net core扩展库之http日志的使用详解的详细内容,更多关于asp.net core扩展库之http日志的资料请关注其它相关文章!