ASP.NET结束Excel进程

开发 后端
本文介绍ASP.NET结束Excel进程,判断进程启动时间来ASP.NET结束Excel进程,虽然看起来有点不妥,但是我用了还从没出过问题,从没错杀其他Excel进程。

一、操作权限问题,有两种方法:

1、使用模拟帐户,在Web.config文件中加入

  1. <!identity impersonate="true" userName="administrator" password=""/> 

2、在DCOM组件服务中给MICROSOFT.EXCEL组件 赋予ASP.NET的操作权限,具体步骤:
(1)打开开始菜单的运行对话框,输入dcomcnfg命令,确定,这时会弹出组件服务窗口
(2)展开计算机-〉我的电脑-〉DCOM配置,找到Microsoft Excel应用程序节点
(3)单击右键-〉属性,选中“安全”选项,在下面三个项目都选择“自定义”,并单击编辑按钮
(4)在启动权限对话框中点击添加按钮,添加相应的用户(注意:如果是WIN2000,XP,则添加“机器名/ASPNET”用户,我这里是以WIN2003为例,WIN2003是添加“NETWORK Service”用户),并赋予***权限

二、ASP.NET结束Excel进程

1、我在上篇随笔中用的是判断进程启动时间来ASP.NET结束Excel进程,虽然看起来有点不妥,但是我用了还从没出过问题,从没错杀其他Excel进程。

2、释放所用到的所有Excel对象的资源,这里拷贝一段代码:

  1. objectmissing=System.Reflection.Missing.Value;  
  2. Microsoft.Office.Interop.Excel.ApplicationmyExcel=newMicrosoft.Office.
    Interop.Excel.ApplicationClass();  
  3. myExcel.Visible=false;  
  4. //打开新文件  
  5. Microsoft.Office.Interop.Excel.WorkbooksmyBooks=myExcel.Workbooks;  
  6. Microsoft.Office.Interop.Excel.WorkbookmyBook=myBooks.
    Open(sourceFile,missing,...);  
  7. Microsoft.Office.Interop.Excel.WorksheetcurSheet=
    (Microsoft.Office.Interop.Excel.Worksheet)myBook.ActiveSheet;  
  8.  
  9. Microsoft.Office.Interop.Excel.Rangerans=
    (Microsoft.Office.Interop.Excel.Range)curSheet.Cells;  
  10. Microsoft.Office.Interop.Excel.Rangeran=null;  
  11. Microsoft.Office.Interop.Excel.RangeranMerge=null;  
  12. Microsoft.Office.Interop.Excel.RangeranRows=null;  
  13. Microsoft.Office.Interop.Excel.RangeranCells=null;  
  14. for(inti=0;i<10;i++)  
  15. {  
  16. for(intj=0;j<10;j++)  
  17. {  
  18. ran=(Microsoft.Office.Interop.Excel.Range)rans[i+1,j+1];  
  19.  
  20. ranranMerge=ran.MergeArea;  
  21. ranRows=ranMerge.Rows;  
  22. intmergeRows=ranRows.Count;  
  23. ranCells=ranMerge.Cells;  
  24. intmergeCells=ranCells.Count;  
  25. Response.Write("<br/>"+i+":"+j+":"+ran.Text);  
  26.  
  27. System.Runtime.InteropServices.Marshal.ReleaseComObject(ranCells);  
  28. ranCells=null;  
  29.  
  30. System.Runtime.InteropServices.Marshal.ReleaseComObject(ranRows);  
  31. ranRows=null;  
  32.  
  33. System.Runtime.InteropServices.Marshal.ReleaseComObject(ranMerge);  
  34. ranMerge=null;  
  35.  
  36. System.Runtime.InteropServices.Marshal.ReleaseComObject(ran);  
  37. ran=null;  
  38. }  
  39. }  
  40.  
  41. System.Runtime.InteropServices.Marshal.ReleaseComObject(rans);  
  42. rans=null;  
  43.  
  44. System.Runtime.InteropServices.Marshal.ReleaseComObject(curSheet);  
  45. curSheet=null;  
  46.  
  47. myBook.Close(false,Type.Missing,Type.Missing);  
  48. System.Runtime.InteropServices.Marshal.ReleaseComObject(myBook);  
  49. myBook=null;  
  50.  
  51. myBooks.Close();  
  52. System.Runtime.InteropServices.Marshal.ReleaseComObject(myBooks);  
  53. myBooks=null;  
  54.  
  55. myExcel.Quit();  
  56. System.Runtime.InteropServices.Marshal.ReleaseComObject(myExcel);  
  57. myExcel=null;  
  58.  
  59. GC.Collect();  
  60. GC.WaitForPendingFinalizers(); 

暂时总结这两个问题,这些解决办法都来源于网上,我这里只是总结一下,顺便把我收集的几个Excel控件给大家下载:
http://files.cnblogs.com/lingyun_k/ExcelWriter.rar

这个有破解
http://files.cnblogs.com/lingyun_k/Aspose%20Excel%20V2.3.1.1.NET.rar

还有一个是ExcelQuicker,功能也挺强的,大家搜一下就可以找到,不过我觉得金质打印王的对Excel操作比它要方便,但是不支持WebForm,以上介绍ASP.NET结束Excel进程

【编辑推荐】

  1. ASP.NET开发技巧之Theme功能浅析
  2. 详解ASP.NET动态编译
  3. Apache支持ASP.NET方法浅析
  4. 浅谈ASP.NET服务器标准控件
  5. ASP.NET中SQL Server数据库备份恢复浅析
责任编辑:佚名 来源: 博客园
相关推荐

2009-08-05 16:59:38

ASP.NET调用Ex

2009-07-28 10:01:16

ASP.NET Exc

2009-08-05 14:19:12

ASP.NET输出EX

2009-07-21 14:32:51

ASP.NET进程模型

2012-08-03 10:20:06

ASP.NET

2009-07-24 14:03:02

IIS ASP.NET

2009-07-22 17:45:35

ASP.NET教程

2009-07-28 17:17:19

ASP.NET概述

2009-08-03 14:22:33

什么是ASP.NET

2009-08-04 11:22:07

ASP.NET数据导入

2009-07-27 12:22:03

ASP.NET和ASPASP.NET入门教程

2009-07-28 10:26:30

ASP.NET操作Ex

2009-08-10 13:32:15

ASP.NET TimASP.NET组件设计

2009-07-29 17:11:25

ASP.NET ISA

2009-07-29 16:08:07

ASP和ASP.NET

2009-07-28 11:23:04

Excel导入SQL

2009-08-03 13:38:18

ASP.NET编程模型

2009-08-03 17:35:07

ASP.NET WebASP.NET编程工具

2009-07-28 09:02:32

asp.net aja

2009-12-02 09:07:45

ASP.NET 4.0
点赞
收藏

51CTO技术栈公众号