- 浏览: 5173003 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
silence19841230:
先拿走看看
SpringBoot2.0开发WebSocket应用完整示例 -
wallimn:
masuweng 写道发下源码下载地址吧!三个相关文件打了个包 ...
SpringBoot2.0开发WebSocket应用完整示例 -
masuweng:
发下源码下载地址吧!
SpringBoot2.0开发WebSocket应用完整示例 -
masuweng:
SpringBoot2.0开发WebSocket应用完整示例 -
wallimn:
水淼火 写道你好,我使用以后,图标不显示,应该怎么引用呢,谢谢 ...
前端框架iviewui使用示例之菜单+多Tab页布局
近日在打开原来写的一个网页程序运行时,出现了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 有一个在应用程序没有模拟时使用的基进程标识(通常,在 IIS 5 上为 {MACHINE}ASPNET,在 IIS 6 上为网络服务)。如果应用程序正在通过 <identity impersonate="true"/> 模拟,则标识将为匿名用户(通常为 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"用户,然后赋予"本地访问"权限.
注意:其中第5步是必须的,否则会出现以下错误:
内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序。 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: system.Runtime.InteropServices.COMException: 内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序。 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。 源错误:
行 535: Application curExcelApp = new ApplicationClass();
行 536: curExcelApp.Application.DisplayAlerts = false;
行 537: Workbook curWorkBook = curExcelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
行 538: Worksheet curWorkSheet = (Worksheet)curWorkBook.Sheets.get_Item(1);
行 539:
按照上述步骤设置好了以后,重新执行程序,还是出现权限不足的问题,问题不知道出现在什么地方,仔细分析提示信息和代码,终于发现了问题的所在,原来是在Web.config中进行了下面的设置:
<identity impersonate="true"/>
而这段话的目的是为每一个请求进行客户端模拟,按照提示信息中的解释,由于没有设置Username,所以当前执行的用户是IUSR_MACHINENAME,而该用户是没有操作Excel组件的权限,为了验证分析是否正确,进行了一下验证:
将这句话删除,执行程序,一切正常;
在Excel的操作权限中加入当前登陆的用户,并进行如下的设置:<identity impersonate="true" userName="***" password="***"/>,执行程序,一切正常;
在Excel的操作权限中加入所有的用户,并进行如下的设置:<identity impersonate="true"/>,执行程序,出现权限不足的错误。
通过以上的验证,我们可以得出,在不进行客户端模拟设置时,asp.net程序调用excel组件时使用的是network service用户(在xp和2000中,使用的是aspnet用户),使用设置<identity impersonate="true"/>进行客户端模拟时,使用的是IUSR_MACHINENAME用户,但该用户没有调用excel组件的权限,即使设置了该用户的相关权限也不行;使用设置<identity impersonate="true" userName="***" password="***"/>进行客户端模拟时,只要设置了相关用户的权限,就可以顺利地调用Excel组件,但是要注意的是:由于asp.net的限制,该用户的密码不能为空。
在处理该问题时,在网上找到了一个比较有用的资料,与大家分享如下:
解决部署在Window server 2003 上Excel.exe进程问题
在操作完Excel以后,每次就会留下一个Execl.exe进程,无论如何也关闭不了,包括用垃圾回收等,原因我也不知道,但是在其他服务器操作系统和xp操作系统上不存在这种问题。
解决此类问题,有一个方法可以借鉴,就是杀死进程的方法,但是有一定的风险,要注意,具体方法如下:
操作进程有一定的风险,所有首先要有此类权限,添加权限方法,在web.Config里面添加权限<identity impersonate="true" userName="登录名" password="密码 "/>
杀死进程方法 publicstaticvoid KillProcess(string processName)
{
system.Diagnostics.Process myproc = new system.Diagnostics.Process(); //得到所有打开的进程
try
{
foreach (Process thisproc in Process.GetProcessesByName(processName))
{ if (!thisproc.CloseMainWindow())
{
if(thisproc!=null)
thisproc.Kill();
} }
}
catch (Exception Exc)
{ throw Exc; }
}
在操作完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 有一个在应用程序没有模拟时使用的基进程标识(通常,在 IIS 5 上为 {MACHINE}ASPNET,在 IIS 6 上为网络服务)。如果应用程序正在通过 <identity impersonate="true"/> 模拟,则标识将为匿名用户(通常为 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"用户,然后赋予"本地访问"权限.
注意:其中第5步是必须的,否则会出现以下错误:
内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序。 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。
说明: 执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: system.Runtime.InteropServices.COMException: 内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序。 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。 源错误:
行 535: Application curExcelApp = new ApplicationClass();
行 536: curExcelApp.Application.DisplayAlerts = false;
行 537: Workbook curWorkBook = curExcelApp.Workbooks.Add(XlWBATemplate.xlWBATWorksheet);
行 538: Worksheet curWorkSheet = (Worksheet)curWorkBook.Sheets.get_Item(1);
行 539:
按照上述步骤设置好了以后,重新执行程序,还是出现权限不足的问题,问题不知道出现在什么地方,仔细分析提示信息和代码,终于发现了问题的所在,原来是在Web.config中进行了下面的设置:
<identity impersonate="true"/>
而这段话的目的是为每一个请求进行客户端模拟,按照提示信息中的解释,由于没有设置Username,所以当前执行的用户是IUSR_MACHINENAME,而该用户是没有操作Excel组件的权限,为了验证分析是否正确,进行了一下验证:
将这句话删除,执行程序,一切正常;
在Excel的操作权限中加入当前登陆的用户,并进行如下的设置:<identity impersonate="true" userName="***" password="***"/>,执行程序,一切正常;
在Excel的操作权限中加入所有的用户,并进行如下的设置:<identity impersonate="true"/>,执行程序,出现权限不足的错误。
通过以上的验证,我们可以得出,在不进行客户端模拟设置时,asp.net程序调用excel组件时使用的是network service用户(在xp和2000中,使用的是aspnet用户),使用设置<identity impersonate="true"/>进行客户端模拟时,使用的是IUSR_MACHINENAME用户,但该用户没有调用excel组件的权限,即使设置了该用户的相关权限也不行;使用设置<identity impersonate="true" userName="***" password="***"/>进行客户端模拟时,只要设置了相关用户的权限,就可以顺利地调用Excel组件,但是要注意的是:由于asp.net的限制,该用户的密码不能为空。
在处理该问题时,在网上找到了一个比较有用的资料,与大家分享如下:
解决部署在Window server 2003 上Excel.exe进程问题
在操作完Excel以后,每次就会留下一个Execl.exe进程,无论如何也关闭不了,包括用垃圾回收等,原因我也不知道,但是在其他服务器操作系统和xp操作系统上不存在这种问题。
解决此类问题,有一个方法可以借鉴,就是杀死进程的方法,但是有一定的风险,要注意,具体方法如下:
操作进程有一定的风险,所有首先要有此类权限,添加权限方法,在web.Config里面添加权限<identity impersonate="true" userName="登录名" password="密码 "/>
杀死进程方法 publicstaticvoid KillProcess(string processName)
{
system.Diagnostics.Process myproc = new system.Diagnostics.Process(); //得到所有打开的进程
try
{
foreach (Process thisproc in Process.GetProcessesByName(processName))
{ if (!thisproc.CloseMainWindow())
{
if(thisproc!=null)
thisproc.Kill();
} }
}
catch (Exception Exc)
{ throw Exc; }
}
在操作完Excel后,调用杀死进程方法就可以了,下一次就会正常调用
发表评论
-
Delphi中编程实现TWebBrowser查找及上一个、下一个功能
2016-08-18 13:58 1361代码比较简单,全部内容如下: //1:向下搜索;-1:向上 ... -
OLEDB的Excel的IMEX和HDR是什么意思
2013-11-23 21:15 2129转自:http://blog.csdn.net/baple/a ... -
c#获取应用程序目录
2013-10-23 22:35 1732string str1 =Process.GetCurrent ... -
Visual C# 方案 -> 文本操作快捷键
2013-10-07 22:34 2064转自:http://technet.microsoft.com ... -
Visual Studio 2005快捷键大全
2013-10-07 22:29 1647转自:http://www.cnblogs.com/mekon ... -
C#正则表达式测试小工具
2013-10-04 18:51 4785C#的正则表达式使用比较方便,但复杂的正则表达式还是需要测 ... -
C#正则表达式语法规则详解
2013-10-04 17:26 4052正则表达式通常包含字 ... -
C# WINFORM 捕获全局异常
2013-10-01 11:56 3043using System; using System.Coll ... -
Visual C# 中XML注释的使用(含注释在开发时显示换行)
2013-10-01 11:54 2469在C#智能注释时,常常希望它能在开发时显示为换行,使得提示更加 ... -
DevExpress汉化(WinForm)
2013-09-19 17:27 8307/* *隔壁老王原创,2013-09-21,转载请保留本人信息 ... -
VC中的CImage类
2011-04-17 22:19 8963今天查找如何实现 ... -
VC旋转图片
2011-04-16 16:45 3778转自:http://hi.baidu.com/sweetpig ... -
VC多线程编程(转)
2010-12-22 21:11 3210原文地址:http://www.cnblo ... -
Manifest的问题
2010-05-11 10:08 2308原始连接:http://www.zming ... -
如何注销windows server2003 服务器中的远程连接
2009-12-14 01:29 3813碰到超过远程连接数而无法连接服务器,可以采用如下方法解决 ... -
访问WebBrowser控件中的HTML源码
2009-12-11 22:13 4125为了实现在自己的程序中显示HTML文档,我们一般采用IE(In ... -
Makefile详解(3/3)
2009-12-01 12:32 1547一、函数库文件的成员 一个函数库文件由多个文件组成。你可以以 ... -
Makefile详解(2/3)
2009-12-01 12:29 2226八、目标变量 前面我们所讲的在Makefile中定义的变量都 ... -
Makefile详解(1/3)
2009-12-01 12:27 2212原文地址:http://blog.csdn ... -
OLE DB 的概念
2009-11-20 22:41 2115简单地说,OLE DB 是 ...
相关推荐
在Asp.net环境中操作Excel文件时遇到权限问题是很常见的现象。通过对服务器环境、DCOM配置、IIS设置等方面的细致调整,大多数情况下都能够成功解决问题。同时,对于一些特殊的情况,如错误码8000401a,也有特定的...
本文将详细介绍如何解决这些常见的配置问题,包括错误代码80070005和8000401a的问题,并提供具体的步骤来确保ASP.NET应用程序能够顺利地创建和操作Word文档。 #### 错误代码80070005: 检索 COM 类工厂中 CLSID 为 {...
在Asp.net MVC框架中,实现在线预览各种办公文档,如Word、Excel、PowerPoint和PDF文件,是一项常见的需求。这通常涉及到技术栈的整合,包括后端处理和前端展示。以下是一些关键知识点: 1. **Asp.net MVC框架**:...
在ASP.NET中实现这个功能,你需要确保代码在服务器上执行时不会引起任何权限问题,因为操作文件系统通常需要相应的权限。同时,考虑到性能和并发性,你应该尽量减少对磁盘的I/O操作,并考虑使用流式处理或内存中的...
本主题聚焦于如何在Asp.NET MVC中实现在线预览功能,特别是针对Word、Excel和PDF等常见文档格式。这是一项重要的需求,因为用户在不下载文件的情况下能够查看文档内容,提升了用户体验和工作效率。 首先,我们要...
Microsoft.Office.Interop.Word是.NET Framework提供的一种方式,可以直接操作Office应用对象模型,但这种方法在服务器环境中可能存在兼容性和性能问题。因此,更常见的是使用第三方库,如EPPlus(用于Excel,但也可...
在ASP.NET中向Word文档插入图片是一个常见的任务,特别是在创建动态报告或自动化文档生成的场景下。这个过程涉及到几个关键的技术点,包括文件操作、对象模型的使用以及服务器与客户端的交互。 首先,我们需要理解...
这款工具提供了丰富的功能,使开发者能够轻松地在Web应用程序中嵌入对多种文档格式的支持,包括PDF、Microsoft Office文档(如Word、Excel、PowerPoint)、图像文件以及更多。 一、ASP.NET文档查看器 ...
在IE浏览器中打开各种类型的文件,如Word、Excel、PDF和TXT,是常见的Web应用程序功能,这主要通过ASP.NET框架实现。ASP.NET是由微软开发的一个用于构建动态网站、Web应用程序和Web服务的平台。它提供了丰富的功能和...
EPPlus是一个开源的.NET类库,它利用Office Open XML标准来读写Excel文件,无需Microsoft Office组件,从而避免了权限问题和依赖性限制。 Office Open XML(OOXML)是由Microsoft开发的一种基于XML的文件格式,它...
在ASP(Active Server Pages)开发中,导出数据到Word或Excel是常见的需求,尤其在报表生成、数据分享等场景中。本篇文章将详细介绍如何在ASP中实现这一功能,确保一次性成功,避免“Excel对象不能创建”的错误。 ...
在这个特定的场景中,我们关注的是如何使用ASP.NET来实现在线预览文档的功能,特别是针对Office文件,如Word、Excel或PowerPoint。 在标题中提到的"asp.net 实现在线预览文档",这意味着我们将探讨如何在ASP.NET...
难以驯服的Word/Excel就变成了普通的、熟悉的、服务器端可调用的.Net组件、Java组件、ASP组件、PHP组件,开发人员再也不用研究复杂的Word/Excel COM自动化细节、学习复杂的VBA语法调用,也不用去应对Word/Excel死...
在使用ASP .NET应用程序操作Excel、Word等Office软件时,有时会在IIS服务器上部署应用过程中遇到错误:“Retrieving the COM class factory for component with CLSID {00024500-0000-0000-C000-000000000046}”。...
6. **与其他Office应用集成**:可以轻松导入或导出Excel、Word等Office文件,实现数据交换。 【多媒体网站构建】 在ASP.NET和ACCESS结合的环境中,构建多媒体网站主要涉及以下几个方面: 1. **媒体资源管理**:...
总结起来,ASP.NET实现仿百度文库文档在线预览是一个涉及文件上传、服务器端转换、前端渲染等多个环节的复杂过程。通过合理选择和组合各种工具与技术,我们可以创建一个高效、安全且用户体验良好的在线预览系统。在...
在.NET开发环境中,GridView控件是ASP.NET网页中常用的数据展示工具,它可以方便地绑定数据库数据并进行分页、排序等操作。而“gridview数据导出到word或Excel完整案例”是一个实用的功能,它允许用户将GridView中的...
3. **安全性与权限管理**:探讨在Web环境中使用Office组件的安全问题,如何设置权限,以及防止潜在的恶意代码执行。 4. **服务器扩展技术**:学习如何通过服务器端脚本(如ASP、.NET)来控制Web组件,实现数据交互...