您现在的位置: 365建站网 > 365学习 > 使用Response.Flush方法实时显示处理过程的状态信息

使用Response.Flush方法实时显示处理过程的状态信息

文章来源:365jz.com     点击数:817    更新时间:2015-11-25 15:33   参与评论

Web项目,在处理大数据量和复杂业务的情况下,用户在浏览器中点击一个按钮后,服务器需要处理几十秒甚至好几分钟,才能将处理结果反馈给用户,在这个漫长的等待过程中,用户面对毫无反应的浏览器会不知所措,即便提示用户正在处理,用户由于不知道服务器的处理状态,在长时间等待后,也会不耐烦或误以为操作失败,而去刷新或者关闭浏览器。

 

怎么应对这种状态,给用户一个更好的体验呢?最好是把处理过程中的状态信息即时反馈给用户,就像杀毒软件扫描文件的时候,把扫描结果即时显示出来。

 

HttpResponse  位于命名空间:  System.Web

HttpResponse 类的方法和属性通过 HttpApplicationHttpContextPageUserControl类的Response属性公开。

HttpResponse 类的方法 Write将信息写入 HTTP 应输出流。

HttpResponse 类的方法 Flush用来向客户端强制发送当前所有缓冲的输出数据,在请求处理期间,允许多次调用该方法。改方法仅仅在回发的情况(不包括异步回发情况)下才被支持。

 

我们可以利用Response.Flush方法来实现上述设想。

 

下面用一个示例来演示如何实时提示处理过程的状态。出于演示的目的,将不考虑具体的业务。

 

在网站项目里,新建一个Web窗体Default.aspx

 

窗体上放置一个Button控件,给Button控件添加Click处理事件。我们将单击这个Button来触发传说中的大数据量的超复杂的业务运算。

 

再往窗体上添加一个<iframe>元素:

<iframe src="Output.aspx" id="OutputFrame" allowtransparency="true" frameborder="1"

    width="400px" height="200px" scrolling="auto" marginheight="0"></iframe>

 

注意<iframe>src属性的值是“Output.aspx”。再追加一个新的Web窗体,名为“Output.aspx”,通过请求它在<iframe>来显示处理结果。

 

删除Output.aspx页面上的所有自动生成的HTML代码。在Page_Load事件里添加处理过程,处理那个传说中的大数据量的超复杂的业务运算。并且在这个处理过程中,实时地用Response.Write方法输出当前处理的状态信息,并且用Response.Flush强制回发给客户端,使用户得到及时的反馈。

 

代码很简单,很容易理解,注意两点:

 

1、在Default.aspxButtonClick事件处理过程中,定义一个Session,存储一个标识和其他画面输入的数据,用于传递到Output.aspx页面,在Output.aspx页面上判断,只有该Session存在,并且标识正确的情况下,才使用Session保存的其他信息,来做那个传说中的大数据量的超复杂的业务运算;

 

2:在每次输出信息的时候,同时输出一行脚本,控制着<iframe>的的垂直滚动条滚动到最底下,让用户不用拖动滚动条就可以看到最新的输出信息。

 

全部的代码如下:

 

Default.aspx

 

Code

 

 

Output.aspx

 

Code

 

演示结果截图

如对本文有疑问,请提交到交流论坛,广大热心网友会为你解答!! 点击进入论坛


发表评论 (817人查看2条评论)
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
用户名: 验证码: 点击我更换图片
最新评论
------分隔线----------------------------