Asp.Net中Excel操作权限的问题
问题1:
近日在打开原来写的一个网页程序运行时,出现了Excel操作权限的问题,具体的说就是在代码中调用下面这段与Excel操作有关的语句时,
Application curExcelApp = new ApplicationClass();
提示权限不足,具体的提示内容如下:
检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:80070005。
说明:执行当前Web请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。异常详细信息:System.UnauthorizedAccessException:检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:80070005。
ASP.NET未被授权访问所请求的资源。请考虑授予ASP.NET 请求标识访问此资源的权限。ASP.NET 有一个在应用程序没有模拟时使用的基进程标识(通常,在IIS5上为{MACHINE}\ASPNET,在IIS6上为
网络服务)。如果应用程序正在通过模拟,则标识将为匿名用户(通常为IUSR_MACHINENAME)或经过身份验证的请求用户。要将ASP.NET访问权限授予某个文件,请在资源管理器中右击该文件,选择“属性”,然后选择“安全”选项卡。单击“添加”添加适当的用户或组。突出显示ASP.
NET帐户,选中所需访问权限对应的框。源错误:
行 533: //创建Excel信息
行 534: object
missing = System.Reflection.Missing.Value; 行 535: Application curExcelApp = new ApplicationClass(); 行 536: curExcelApp.Application.DisplayAlerts = false; 行 537: Workbook curWorkBook = curExcelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
原来碰到过这种情况,知道是由于Excel的DCom组件权限不足所引起的,所以按照原来的步骤进行设置,如下所示:
1、在服务器上安装office的Excel
软件;
2、在“开始”->“运行”中输入dcomcnfg.exe启动“组件服务”;
3、依次双击“组件服务”->“计算机”->“我的电脑”->“DCOM配置”; 4、在“DCOM配置”中找到“Microsoft Excel应用程序”,在它上面点击右键,然后点击“属性”,弹出“Microsoft Excel应用
程序属性”对话框;
5、点击“标识”标签,选择“交互式用户”;
6、点击“安全”标签,在“启动和激活权限”上点击“自定义”,然后点击对应的“编辑”按钮,在弹出的“安全性”对话框中填加一个“NETWORK SERVICE”用户(注意要选择本
计算机名),并给它赋予“本地启动”和“本地激活”权限。在XP系统和2000系统中添加ASPNET用户;
7、依然是“安全”标签,在“访问权限”上点击“自定义”,然后点击“编辑”,在弹出的“安全性”对话框中也填加一个“NETWORK SERVICE”用户,然后赋予“本地访问”权限。在XP
系统和2000系统中添加ASPNET用户。
注意:其中第5步是必须的,否则会出现以下错误:
内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何
文档。要想获得更多的可用内存,请关闭不再使用的
工作簿或程序。要想释放磁盘空间,请删除相应磁盘上不需要的文件。
问题2:
在研究此方法时,遇到了这样一个问题:检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:8000401a。在服务器上调试程序没有发生,但通过网页来访问时产生了,通过在网上查找,终于找到解决方法了。
解决办法:
运行dcomcnfg打开组件服务,依次展开“组件服务”→“计算机”→“我的电脑”→“DCOM配置”,找到“Microsoft Excel应用程序”或“Microsoft Word应用程序”,右键打开属性对话框,
点击“标识”选项卡,选择“启动用户”
点击“安全”选项卡,依次把“启动和激活权限”、“访问权限”、“配置权限”都选择为自定义,然后依次点击它们的编辑,把everyone添加进去,并加入所有的权限。
OK,解决此问题!