exp*_*uin 13 c# httpresponse httpcontext
我已经设置了一些日志中间件,可以使用 HttpContext 获取和记录信息。
我需要将 HttpResponse.Body 的位置设置为 0 以读取整个流,但是,无论我尝试什么,它都会抛出“不支持指定的方法”并失败。
这对我来说很奇怪,因为 position 内置于 HttpResponse.Body 中,我之前成功使用过它。
我还尝试使用 HttpResponse.Body.Seek 获得相同的结果。
在这一点上我被卡住了,任何帮助将不胜感激。
更新:一旦我将 response.body 移动到新的内存流中,我就能够改变它的位置,但是,现在它返回一个空的主体。
public async Task Invoke(HttpContext context)
{
//Retrieve request & response
var request = context.Request;
var response = context.Response;
if (request.Path != "/")
{
var reqBody = request.Body;
var resBody = response.Body;
string path = request.Path;
string method = request.Method;
string queryString = HttpUtility.UrlDecode(request.QueryString.ToString());
int statusCode = context.Response.StatusCode;
var buffer = new byte[Convert.ToInt32(request.ContentLength)];
await request.Body.ReadAsync(buffer, 0, buffer.Length);
var reqBodyText = Encoding.UTF8.GetString(buffer);
request.Body = reqBody;
var responseBodyStream = new MemoryStream();
context.Response.Body = responseBodyStream;
await _next(context);
responseBodyStream.Seek(0, SeekOrigin.Begin);
var resBodyText = new StreamReader(responseBodyStream).ReadToEnd();
responseBodyStream.Seek(0, SeekOrigin.Begin);
await responseBodyStream.CopyToAsync(context.Response.Body);
...
}
}
Run Code Online (Sandbox Code Playgroud)
jhh*_*ams 12
根据解决此GitHub 问题的评论,您需要启用缓冲。
为此,请将以下代码片段添加到您的Startup.cs Configure方法中:
app.Use(async (context, next) =>
{
context.Request.EnableBuffering();
await next();
});
Run Code Online (Sandbox Code Playgroud)
我能够解决这个问题:
首先,我将响应设置为其自己的内存流,并在设置流后调用await _next(context):
using var responseBodyStream = new MemoryStream();
var previousBodyStream = context.Response.Body;
context.Response.Body = responseBodyStream;
await _next(context);
Run Code Online (Sandbox Code Playgroud)
然后,一旦我这样做了,我注意到我得到了一个空的主体,这是由于尝试将一个空的主体设置回响应上下文:
responseBodyStream.Flush();
responseBodyStream.Seek(0, SeekOrigin.Begin);
await responseBodyStream.CopyToAsync(previousBodyStream);
context.Response.Body = previousBodyStream;
Run Code Online (Sandbox Code Playgroud)
我删除了这条线,一切都开始正常工作。
| 归档时间: |
|
| 查看次数: |
7463 次 |
| 最近记录: |