Response 对应Http中的响应模式,除了Response会向浏览器传送数据之外,Http响应报文中的信息

也会通过它来传送。而且Http报文是隐藏在浏览器内部的,一般人看不到,可以使用 httpwatch等

工具来查看,当前响应的状态(200,ok) 当前Http协议版本(Http/1.1) 当前响应内容的字节长度(不包括Http

响应报文),当前浏览器和服务器端的链接状态(connection:close)等。


在ASP.NET后台,Response是用于象浏览器发送响应数据,以及一些数据格式规定的信息。

在ASP.NET中,Response是有一个缓存机制的,它不会说是你写一句Response就往浏览器发送一条,

它会将所有的响应数据流存放在响应缓存中,在某个特定的时机,在一次性的传给浏览器。

在asp.net后台网页生命周期中呈现之前的Response输出流信息,永远都是在当前结构这个响应信息

的浏览器的HTML标签的头部。


一般默认情况下。ASP.NET的Response输出响应流都是缓存的,

我们可以通过Response.Buffer或者 BufferOutput属性等于false来告诉asp.net

框架,我们不需要把响应数据缓存起来。(有.NET反编译器可以知道,BufferOutput内部其实还是调用的Buffer属性,所以你

设置其中的一个就可以了。)


什么情况下,我们需要ASP.NET框架不缓存数据呢。在做大量数据录入的时候,或者是某些Web应用程序

在线安装的时候,我们必须让用户知道时时的安装信息。这个时候,就可以禁掉asp.net默认缓存功能。

还有一种方式是,Response.Flush();想当前客户发送所有缓冲信息。


西面可以做做一个例子来模拟这个效果:

一般处理文件:Setup.aspx

有responseText没有responseJson response has no len_框架

模拟效果:

有responseText没有responseJson response has no len_java_02

数据是逐条显示出来的。


Response.Flush() 和Response.Buffer=false的区别。

从解释上也可以看出来,Flush是将当前缓冲区的数据发送到浏览器,也就是说,在调用

这个方法之前,缓冲区仍然是在缓存数据的。

而Response.buffer=false 则是 缓冲区从来就不缓冲数据,一有数据就直接写到浏览器。