中途关闭ASP.NET是否影响服务器端执行?

开发 后端
如果一个ASP.NET页面执行到一半的时候被关闭了,服务器端对应的页面代码还在执行么?理论上来说是仍在执行的,不过,还有一些要点是需要注意的。

在执行ASP.NET页面过程中,总难免会出现这样那样的问题,比较典型的一个问题就是当一个ASPX页面执行到一半的时候,浏览器关闭了这个页面,那么服务器端对应的这个页面的代码还在执行么?

经验证明,除非你在代码里面做了特殊判断,否则代码仍然正在执行。

注意点:

1、客户端显示页面的时候,后台已经执行完了的页面对象早已经不存在了。当然这时候谈不上服务器段执行不执行的问题了。

2、页面还没有返回,处于等待状态的时候。关闭ASPX页面,才会涉及到上面提到的服务器端仍然在执行的情况。

3、客户端关闭的时候根本不向服务器发送指令。

4、除非你代码里面做了特殊判断,这里的特殊判断指用

  1. if(!Response.IsClientConnected) 

来检测状态而用代码终止运行。

下面的简单代码就是演示关闭页面后,看是否仍然在执行?

你可以在这个页面打开后, 还没有返回任何信息的时候把这个页面关闭,然后看指定目录下是否有对应文件被创建并填写内容。

  1. protected void Page_Load(object sender, EventArgs e)   
  2. {   
  3. StringBuilder txt = new StringBuilder();   
  4. txt.AppendLine();   
  5. txt.AppendLine(DateTime.Now.ToString("u"));   
  6. txt.AppendLine("asvd");   
  7. Response.Write(DateTime.Now.ToString("u"));   
  8. Response.Write("\r\n");   
  9. Thread.Sleep(50000);   
  10.  
  11. txt.AppendLine(DateTime.Now.ToString("u"));   
  12. Response.Write(DateTime.Now.ToString("u"));   
  13. Response.Write("\r\n");   
  14. // 把一些信息写到另外一个文件,借此察看是否正在运行   
  15. string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");   
  16. if (!Directory.Exists(dir))   
  17. Directory.CreateDirectory(dir);   
  18. DateTime dt = DateTime.Now;   
  19. string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);   
  20. string fileName = Path.Combine(dir, shortfileName);   
  21. StreamWriter sw;   
  22. if (File.Exists(fileName))   
  23. sw = File.AppendText(fileName);   
  24. else   
  25. sw = File.CreateText(fileName);   
  26. sw.Write(txt.ToString());   
  27. sw.Close();   
  28. sw = null;   
  29. }  

作了特殊判断的情况简单例子:

注意: IsClientConnected 的判断在 VS.net 开发工具自带的开发站点 ASP.NET Development Server 是不支持的。 ASP.NET Development Server 永远返回 true 。
IIS 才是支持的。

  1. protected void Page_Load(object sender, EventArgs e)   
  2. {   
  3. StringBuilder txt = new StringBuilder();   
  4. for (int i = 0; i < 100; i++)   
  5. {   
  6. if (this.Response.IsClientConnected)   
  7. {   
  8. txt.AppendLine();   
  9. txt.AppendLine(DateTime.Now.ToString("u"));   
  10. txt.AppendLine(i.ToString());   
  11. Response.Write(DateTime.Now.ToString("u"));   
  12. Response.Write("\r\n");   
  13. Thread.Sleep(500);   
  14. }   
  15. else   
  16. {   
  17. Response.End();   
  18. return;   
  19. }   
  20. }   
  21. txt.AppendLine(DateTime.Now.ToString("u"));   
  22. Response.Write(DateTime.Now.ToString("u"));   
  23. Response.Write("\r\n");   
  24. // 把一些信息写到另外一个文件,借此察看是否正在运行   
  25. string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");   
  26. if (!Directory.Exists(dir))   
  27. Directory.CreateDirectory(dir);   
  28. DateTime dt = DateTime.Now;   
  29. string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);   
  30. string fileName = Path.Combine(dir, shortfileName);   
  31. StreamWriter sw;   
  32. if (File.Exists(fileName))   
  33. sw = File.AppendText(fileName);   
  34. else   
  35. sw = File.CreateText(fileName);   
  36. sw.Write(txt.ToString());   
  37. sw.Close();   
  38. sw = null;   

这个例子中是发现中断,就抛弃之前做的任何东西。 #p#

当然我们也可以简单的修改上述代码,让把已经处理完成的东西记录下来,类似下面的代码

  1. protected void Page_Load(object sender, EventArgs e)   
  2. {   
  3. StringBuilder txt = new StringBuilder();   
  4. for (int i = 0; i < 100; i++)   
  5. {   
  6. if (this.Response.IsClientConnected)   
  7. {   
  8. txt.AppendLine();   
  9. txt.AppendLine(DateTime.Now.ToString("u"));   
  10. txt.Append("********** ");   
  11. txt.AppendLine(i.ToString());   
  12. Response.Write(DateTime.Now.ToString("u"));   
  13. Response.Write("\r\n");   
  14. Thread.Sleep(500);   
  15. }   
  16. else   
  17. {   
  18. break;   
  19. }   
  20. }   
  21. txt.AppendLine(DateTime.Now.ToString("u"));   
  22. Response.Write(DateTime.Now.ToString("u"));   
  23. Response.Write("\r\n");   
  24. // 把一些信息写到另外一个文件,借此察看是否正在运行   
  25. string dir = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "logs");   
  26. if (!Directory.Exists(dir))   
  27. Directory.CreateDirectory(dir);   
  28. DateTime dt = DateTime.Now;   
  29. string shortfileName = string.Format("errors_{0:0000}{1:00}{2:00}.log", dt.Year, dt.Month, dt.Day);   
  30. string fileName = Path.Combine(dir, shortfileName);   
  31. StreamWriter sw;   
  32. if (File.Exists(fileName))   
  33. sw = File.AppendText(fileName);   
  34. else   
  35. sw = File.CreateText(fileName);   
  36. sw.Write(txt.ToString());   
  37. sw.Close();   
  38. sw = null;   

需要注意的是, 使用 isClientConnected 是要占用一定的系统资源的。

isClientConnected 实际上需要向客户端输出一点东西,然后才知道客户端是否仍然在线。

这样,除非你的应用非常耗时,否则建议你不要用 isClientConnected 。 免得判断 isClientConnected 使用的资源比你实际业务逻辑使用的资源还要多。

在任何情况下, Response.IsClientConnected 都要有些开销,所以,只有在执行至少要用 500 毫秒(如果想维持每秒几十页的吞吐量,这是一个很长的时间了)的操作前才使用它。作为通常的规则,不要在紧密循环的每次迭代中调用它,例如当绘制表中的行,可能每 20 行或每 50 行调用一次。

【编辑推荐】

  1. 专题:ASP.NET开发教程
  2. ASP.NET开发中关于Web标准的几点建议
  3. ASP.NET开发环境搭建浅析
责任编辑:林琳 来源: 脚本之家
相关推荐

2009-07-27 12:56:27

控件CheckBoxLASP.NET服务器

2011-07-06 13:41:06

ASP.NET

2009-08-01 10:07:58

ASP.NET服务器控ASP.NET

2009-08-10 14:08:15

ASP.NET服务器控ASP.NET组件设计

2014-11-14 11:03:56

微软.NET

2009-09-10 17:11:12

ASP.NET 关闭页

2009-08-03 18:00:00

ASP.NET服务器控

2011-07-12 15:17:02

ASP.net服务器控件

2009-08-04 17:18:37

2009-07-28 10:43:23

Web服务器ASP.NET

2009-08-10 14:25:33

ASP.NET服务器控

2009-10-20 17:28:02

VB.NET服务器端

2009-07-23 13:26:21

2009-08-04 13:39:43

ASP.NET 2.0

2009-08-04 13:10:05

ASP.NET服务器控

2009-08-04 15:13:38

2009-08-06 14:16:04

ASP.NET服务器控

2009-08-07 13:56:46

ASP.NET控件开发

2011-04-13 15:13:01

ASP.NET

2009-08-06 14:42:54

ASP.NET服务器控
点赞
收藏

51CTO技术栈公众号