好久没写csdn了,最近在用.net core api服务的时候
使用中间件来对Request的 body进行解密操作时,使用了EnableBuffering读取Body中的数据,解密总是失败,检查后发现,读取Body的数据,前半截正常,后面全部变成了空格,遂在网上查找相关资料,发现了是写的方式不对,记录mark一下(转运下其他博主的内容)
.Net Core 对于body多次读取,.net core2.0 使用EnableRewind(),.net core 3.0使用EnableBuffering(),
该参数在第一次读取body之前开启,之后body信息可以多次读取;
core时代取消了之前的stream.position=0写法,
虽然 **var byts = new byte[request.ContentLength.Value]**中的request.ContentLength.Value超过1024语法并没有错,并且代码也正常执行,但是对于流读取的话,一次最多是1024,如果一次需要读取的大于1024,也不会报错,会截断,就是读取的信息不全。
(这个导致了我后面的AES解密失败),搞了好久才发现内容被截断了,现在分享给大家,让你们少走点弯路。
ps:我就是上传了一长段数据,读取的时候发现后半截都是空格
错误的写法
// 获取请求参数
var request = actionContext.HttpContext.Request;
request.EnableBuffering();
var stream = actionContext.HttpContext.Request.Body;
// 限制 读取 丢失
var byts = new byte[request.ContentLength.Value];
stream.Read(byts, 0, byts.Length);
var postJson = Encoding.UTF8.GetString(byts);
actionContext.HttpContext.Request.Body.Position = 0
正确的写法
// 获取请求参数
var request = actionContext.HttpContext.Request;
request.EnableBuffering();
var postJson = "";
var stream = actionContext.HttpContext.Request.Body;
long? length = actionContext.HttpContext.Request.ContentLength;
if (length != null && length > 0)
{
// 使用这个方式读取,并且使用异步
StreamReader streamReader = new StreamReader(stream, Encoding.UTF8);
postJson = streamReader.ReadToEndAsync().Result;
}
actionContext.HttpContext.Request.Body.Position = 0
原文链接:https://codeleading.com/article/71033184259/