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

1、使用模拟帐户,在Web.config文件中加入
- />
 
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对象的资源,这里拷贝一段代码:
- objectmissing=System.Reflection.Missing.Value;
 - Microsoft.Office.Interop.Excel.ApplicationmyExcel=newMicrosoft.Office.
 
Interop.Excel.ApplicationClass();- myExcel.Visible=false;
 - //打开新文件
 - Microsoft.Office.Interop.Excel.WorkbooksmyBooks=myExcel.Workbooks;
 - Microsoft.Office.Interop.Excel.WorkbookmyBook=myBooks.
 
Open(sourceFile,missing,...);- Microsoft.Office.Interop.Excel.WorksheetcurSheet=
 
(Microsoft.Office.Interop.Excel.Worksheet)myBook.ActiveSheet;- Microsoft.Office.Interop.Excel.Rangerans=
 
(Microsoft.Office.Interop.Excel.Range)curSheet.Cells;- Microsoft.Office.Interop.Excel.Rangeran=null;
 - Microsoft.Office.Interop.Excel.RangeranMerge=null;
 - Microsoft.Office.Interop.Excel.RangeranRows=null;
 - Microsoft.Office.Interop.Excel.RangeranCells=null;
 - for(inti=0;i<10;i++)
 - {
 - for(intj=0;j<10;j++)
 - {
 - ran=(Microsoft.Office.Interop.Excel.Range)rans[i+1,j+1];
 - ranranMerge=ran.MergeArea;
 - ranRows=ranMerge.Rows;
 - intmergeRows=ranRows.Count;
 - ranCells=ranMerge.Cells;
 - intmergeCells=ranCells.Count;
 - Response.Write("
 
"+i+":"+j+":"+ran.Text);- System.Runtime.InteropServices.Marshal.ReleaseComObject(ranCells);
 - ranCells=null;
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(ranRows);
 - ranRows=null;
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(ranMerge);
 - ranMerge=null;
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(ran);
 - ran=null;
 - }
 - }
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(rans);
 - rans=null;
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(curSheet);
 - curSheet=null;
 - myBook.Close(false,Type.Missing,Type.Missing);
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(myBook);
 - myBook=null;
 - myBooks.Close();
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(myBooks);
 - myBooks=null;
 - myExcel.Quit();
 - System.Runtime.InteropServices.Marshal.ReleaseComObject(myExcel);
 - myExcel=null;
 - GC.Collect();
 - 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进程
【编辑推荐】
                网页名称:ASP.NET结束Excel进程
                
                网址分享:http://www.csdahua.cn/qtweb/news35/335385.html
            
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网