zoukankan      html  css  js  c++  java
  • Asp.NetCore3.1 asp.net 5.0 中多次读取 Request.Body Ajax Post过来的JSON数据等 已验证有效

    首先,以下方式是错误的(这个重复读取只能在using语句里面生效,因为用了ms对象赋值,当using结束后ms资源被释放,Request.Body就无法再读了)
            [HttpPost]
            public async Task<string> Post()
            {
    
                //StreamReader sr = new StreamReader(Request.Body);
                //string data = await sr.ReadToEndAsync();
    
                string data = "";
                using (MemoryStream ms = new MemoryStream())
                {
                    await Request.Body.CopyToAsync(ms);
                    //设置当前流的位置为0
                    ms.Seek(0, SeekOrigin.Begin);
                    logger.LogInformation("ms.Length=" + ms.Length);
                    //这里ReadToEnd执行完毕后requestBodyStream流的位置会从0到最后位置(即request.ContentLength)
                    data = new StreamReader(ms, Encoding.UTF8).ReadToEnd();
                    logger.LogInformation("data=" + data);
    
                    //设置当前流的位置为0
                    ms.Seek(0, SeekOrigin.Begin);
                    Request.Body = ms;
                    StreamReader sr = new StreamReader(Request.Body);
                    string data2 = await sr.ReadToEndAsync();
                    logger.LogInformation("data2=" + data2);
                }
    
                string header = $"请求头:
    ";
                foreach (var item in Request.Headers)
                {
                    header += $"{item.Key}:{item.Value}
    ";
                }
                logger.LogInformation(header);
    
                var ip = Request.Headers["X-Forwarded-For"].FirstOrDefault();
                if (string.IsNullOrEmpty(ip))
                {
                    //ip = Request.HttpContext.Connection.RemoteIpAddress.ToString();
                    //ip = Request.HttpContext.Connection.LocalIpAddress.MapToIPv4().ToString();
                    ip = Request.HttpContext.Connection.RemoteIpAddress.MapToIPv4().ToString();
                }
                logger.LogInformation("ip=" + ip);
    
                //...
            }
    

      


    正确方式是:
            [HttpPost]
            public async Task<string> Post()
            {
                //StreamReader sr = new StreamReader(Request.Body);
                //string data = await sr.ReadToEndAsync();
    
                string data = "";
    
                //Request.EnableBuffering();可以实现多次读取Body
                Request.EnableBuffering();
                StreamReader sr = new StreamReader(Request.Body);
                data = await sr.ReadToEndAsync();
                logger.LogInformation("data=" + data);
                Request.Body.Seek(0, SeekOrigin.Begin);
    
                //再次读取 依然可以成功读到
                Request.EnableBuffering();
                StreamReader sr2 = new StreamReader(Request.Body);
                string data2 = await sr2.ReadToEndAsync();
                logger.LogInformation("data2=" + data2);
                Request.Body.Seek(0, SeekOrigin.Begin);
                
    
                string header = $"请求头:
    ";
                foreach (var item in Request.Headers)
                {
                    header += $"{item.Key}:{item.Value}
    ";
                }
                logger.LogInformation(header);
    
                var ip = Request.Headers["X-Forwarded-For"].FirstOrDefault();
                if (string.IsNullOrEmpty(ip))
                {
                    //ip = Request.HttpContext.Connection.RemoteIpAddress.ToString();
                    //ip = Request.HttpContext.Connection.LocalIpAddress.MapToIPv4().ToString();
                    ip = Request.HttpContext.Connection.RemoteIpAddress.MapToIPv4().ToString();
                }
                logger.LogInformation("ip=" + ip);
    
                //...
            }
     
  • 相关阅读:
    将博客搬至CSDN
    ActiveMQ 的可持久化(六)
    ActiveMQ之协议(五)
    ActiveMQ与Spring / SpringBoot 整合(四)
    ActiveMQ之JMS及保证消息的可靠性<持久化、事务、签收>(三)
    ActiveMQ部署和代码尝试(二)
    ActiveMQ初步安装使用(一)
    Redis之哨兵机制(五)
    Redis主从复制(读写分离)(四)
    Redis持久化(三)
  • 原文地址:https://www.cnblogs.com/webenh/p/13111476.html
Copyright © 2011-2022 走看看