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
模拟效果:
数据是逐条显示出来的。
Response.Flush() 和Response.Buffer=false的区别。
从解释上也可以看出来,Flush是将当前缓冲区的数据发送到浏览器,也就是说,在调用
这个方法之前,缓冲区仍然是在缓存数据的。
而Response.buffer=false 则是 缓冲区从来就不缓冲数据,一有数据就直接写到浏览器。