如何解决Audit.Net 中的响应标头中缺少位置标头
在使用 Audit.Net 时,我还包括要审核的整个响应,例如响应内容、标头和 IncludeHeaders,以下是我的配置:
mvcoptions.AddAuditFilter(a => a
.LogRequestIf(d => d.HttpContext.Request.Method != HttpMethods.Get)
.WithEventType("{verb}.{controller}.{action}")
.IncludeHeaders()
.IncludeResponseBody()
.IncludeResponseHeaders());
但我只能看到下面的响应标头。
"Headers": {
"Connection": "keep-alive","Content-Type": "application/json","Accept": "*/*","Accept-Encoding": "gzip,deflate,br","Host": "localhost:50266","User-Agent": "PostmanRuntime/7.26.10","Content-Length": "3503","Postman-Token": "645b83e3-d1b6-40f8-b615-85052b614b37"
},"ResponseHeaders": {
"Request-Context": "appId=xxxxxxx","Referrer-Policy": "no-referrer","X-Content-Type-Options": "nosniff","Content-Security-Policy": "default-src 'self';"
}
我的响应还包含 Location 标头,但在审核日志中看不到相同的标头。此请求是通过 Postman 提出的,postman 中的响应标头如下所示:
位置标题在邮递员中清晰可见,但审核日志中缺少相同的内容,我在这里错过了什么?请指点一下?
解决方法
您应该使用提供的中间件来获取响应标头,因为大多数响应标头都添加到在操作过滤器之后执行的结果过滤器上,而 AuditApiGlobalFilter
是一个动作过滤器。
recommended approach 用于配置动作过滤器和中间件,以便您获得动作的特定信息以及之后添加的任何信息,例如响应头。此外,包括中间件将允许审核未到达控制器/操作的请求。
所以只需将以下内容添加到您的启动中:
public void Configure(IApplicationBuilder app)
{
app.UseAuditMiddleware(_ => _
.FilterByRequest(d => d.HttpContext.Request.Method != HttpMethods.Get)
.IncludeHeaders()
.IncludeResponseBody()
.IncludeResponseHeaders()
.WithEventType("{verb}.{controller}.{action}"));
// ...
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。