ASP.NET结束Excel进程
创始人
2024-04-25 13:10:46
0

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

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

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

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...
2012年第四季度互联网状况报... [[71653]]  北京时间4月25日消息,据国外媒体报道,全球知名的云平台公司Akamai Te...