是否可以在 Application Insights 中查看请求的响应正文?我看过很多关于请求正文的问题/文章,但没有发现有关响应正文的内容。
我正在构建一个 MVC 核心 2.1 Web Api。
相关文章:
在 Application Insights 中查看 POST 请求正文
这是我的代码,从流创建阅读器时出现异常,即“流不可读”。.
public class ResponseBodyInitializer : ITelemetryInitializer
{
readonly IHttpContextAccessor httpContextAccessor;
public ResponseBodyInitializer(IHttpContextAccessor httpContextAccessor)
{
this.httpContextAccessor = httpContextAccessor;
}
public void Initialize(ITelemetry telemetry)
{
if (telemetry is RequestTelemetry requestTelemetry)
{
HttpContext httpContext = httpContextAccessor.HttpContext;
HttpRequest request = httpContext.Request;
HttpResponse response = httpContext.Response;
if (request.Method == HttpMethods.Post ||
request.Method == HttpMethods.Put)
{
//Log the response body
if (httpContext.Response.HasStarted)
{
const string responseBody = "ResponseBody";
if (requestTelemetry.Properties.ContainsKey(responseBody))
{
return;
}
try
{
var stream = new StreamReader(response.Body);
var body = stream.ReadToEnd();
response.Body.Position = 0;
requestTelemetry.Properties.Add(responseBody, body);
}
catch (Exception ex)
{
throw ex;
}
}
}
}
}
}
- - - - - - - - - - - - - - - - - 更新 - - - - - - - - -----------------
这是我记录请求和响应正文的完整代码。请求正文已正确记录(使用 request.EnableRewind();),但是,响应部分在流读取器上引发异常Stream 不可读。
public class RequestBodyAndResponseBodyInitializer : ITelemetryInitializer
{
readonly IHttpContextAccessor httpContextAccessor;
public RequestBodyAndResponseBodyInitializer(IHttpContextAccessor httpContextAccessor)
{
this.httpContextAccessor = httpContextAccessor;
}
public void Initialize(ITelemetry telemetry)
{
if (telemetry is RequestTelemetry requestTelemetry)
{
HttpContext httpContext = httpContextAccessor.HttpContext;
HttpRequest request = httpContext.Request;
HttpResponse response = httpContext.Response;
if (request.Method == HttpMethods.Post ||
request.Method == HttpMethods.Put)
{
//1- Log the request body
if (request.Body.CanRead)
{
const string requestBody = "RequestBody";
if (requestTelemetry.Properties.ContainsKey(requestBody))
{
return;
}
//Allows re-usage of the stream
request.EnableRewind();
var stream = new StreamReader(request.Body);
var body = stream.ReadToEnd();
//Reset the stream so data is not lost
request.Body.Position = 0;
requestTelemetry.Properties.Add(requestBody, body);
}
//2- Log the response body
else if (httpContext.Response.HasStarted)
{
//Allows re-usage of the stream
//request.EnableRewind();
const string responseBody = "ResponseBody";
if (requestTelemetry.Properties.ContainsKey(responseBody))
{
return;
}
try
{
//var stream = new StreamReader(response.Body);
//var body = stream.ReadToEnd();
//response.Body.Position = 0;
//requestTelemetry.Properties.Add(responseBody, body);
using (var memoryStream = new MemoryStream())
{
var stream = response.Body;
response.Body = memoryStream;
await next(context);
var body = new StreamReader(memoryStream).ReadToEnd();
//logger?.LogDebug($"Response: {responseBody}");
response.Body = stream;
}
}
catch (Exception ex)
{
throw ex;
}
}
else { }
}
}
}
}