ASP.NET结束Excel进程

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

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

 
 
 
  1. /> 

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("
    "+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数据库备份恢复浅析

标题名称:ASP.NET结束Excel进程
文章分享:http://www.mswzjz.cn/qtweb/news35/335385.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能