Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/asp.net/36.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# ASP.NETWebAPI读取inputstream两次_C#_Asp.net_Asp.net Web Api - Fatal编程技术网

C# ASP.NETWebAPI读取inputstream两次

C# ASP.NETWebAPI读取inputstream两次,c#,asp.net,asp.net-web-api,C#,Asp.net,Asp.net Web Api,我正在使用ASP.NET Web API,我有一个控制器,其代码类似于: [Route("UpdateData")] [HttpPost] public HttpResponseMessage UpdateData([FromBody]RequestClasses.UpdataData data) { string json; if (HttpContext.Current.Request.InputStream.Length > 0) { Http

我正在使用ASP.NET Web API,我有一个控制器,其代码类似于:

[Route("UpdateData")]
[HttpPost]
public HttpResponseMessage UpdateData([FromBody]RequestClasses.UpdataData data)
{
    string json;
    if (HttpContext.Current.Request.InputStream.Length > 0)
    {
        HttpContext.Current.Request.InputStream.Position = 0;
        using (var inputStream = new StreamReader(HttpContext.Current.Request.InputStream))
        {
            json = inputStream.ReadToEnd();
        }
    }

    // Dencrypt json

return Request.CreateResponse(HttpStatusCode.OK);
}
作为输入参数,我有“[FromBody]RequestClasses.UpdateData”。为了能够显示帮助页面(使用Microsoft.AspNet.WebApi.HelpPage),我使用了这个工具

在这个方法中接收的数据对象是加密的,我需要解密它

我的问题是无法调用HttpContext.Current.Request.InputStream,因为“[FromBody]RequestClasses.UpdateData”已处理了我的InputStream


有什么好办法解决这个问题吗?因为我仍然需要帮助页面来显示使用哪些参数来调用该方法。

By design ASP.NET Web API只能读取有效负载输入流一次。因此,如果参数binder读取了它,那么就没有可用的。这就是人们在评论中告诉您使用无参数方法的方式,并且自己阅读有效负载


但是,您希望有参数可以在“帮助”页面中看到它们。有一个解决方案:在前面的步骤中对请求进行解密。为此,可以使用消息处理程序。请看以下内容:

为什么不删除该参数?因为该参数为我提供了一个帮助页面,显示要发送给该方法的json对象。也许还有另一种方法可以让WebAPI帮助页面生成这个。这是我问题的一部分,您可以删除参数,然后在读取InputStream时构建它。通过这种方式,您可以同时拥有这两种功能,但缺点是,您必须自己执行反序列化。为什么要手动加密发送的数据这正是SSL(即HTTPS)的设计初衷。