Web.config上添加了“<identity impersonate="true"/>”
近日在打开原来写的一个网页程序运行时,出现了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信息
原来碰到过这种情况,知道是由于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 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序。 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。
按照上述步骤设置好了以后,重新执行程序,还是出现权限不足的问题,问题不知道出现在什么地方,仔细分析提示信息和代码,终于发现了问题的所在,原来是在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后,调用杀死进程方法就可以了,下一次就会正常调用
分享到:
相关推荐
### C#操作Excel知识点 ...以上就是关于C#操作Excel的基本知识点和技术细节,包括读取、插入、修改数据、导出、写保护以及根据不同权限设置保护级别的方法。希望这些内容能帮助您更好地理解和使用C#中的Excel操作技术。
7. **并发和效率**:由于Interop依赖Excel进程,多线程操作可能导致性能问题。相比之下,NPOI在处理大量数据时效率更高,更适合服务器环境。 8. **错误处理**:处理可能的异常,如文件不存在、权限不足或公式错误等...
通过上述分析,我们不仅了解了C#操作Excel的具体实现细节,还深入探讨了在IIS环境下进行Excel操作时需要注意的权限设置问题。正确理解和实施这些技术与策略,对于开发高效稳定的基于Web的Excel操作应用程序至关重要...
操作Excel文件时,务必考虑可能出现的异常,例如文件不存在、权限问题等,使用`try-catch`块捕获并处理这些异常。 8. **性能优化** 当处理大量数据时,考虑使用`Value2`属性代替`Value`,以减少内存占用。此外,...
本主题聚焦于如何使用C#操作Excel文件,这是一个常见的需求,特别是在数据分析、报表生成和数据导入导出等场景。Excel文件通常以.XLS或.XLSX格式存在,而C#提供了一些库和方法来方便开发者进行处理。 首先,我们来...
10. **错误处理和异常处理**: 在进行Excel操作时,应妥善处理可能出现的错误,如文件不存在、权限问题、数据格式错误等,通常通过try-catch块捕获并处理异常。 总之,C#操作Excel涉及的技术包括但不限于COM互操作、...
2、内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。
9. **异常处理**: 操作Excel时可能会遇到各种错误,如文件未找到、权限问题等。因此,需要添加适当的异常处理代码以确保程序的健壮性。 10. **效率考虑**: 使用Interop操作Excel效率较低,且可能依赖于用户的Office...
操作Excel时,要注意处理可能出现的异常,如文件不存在、权限问题等。另外,处理大量数据时,应尽量避免一次性加载所有数据,可以分批读写以优化性能。 9. **自动化工作流** 在实际项目中,C#操作Excel常用于自动...
在IT行业中,C#是一种广泛使用的编程语言,尤其在开发Windows桌面应用、Web应用以及游戏等领域。本话题聚焦于如何利用C#...在实践中,还需要注意处理可能出现的异常,如文件不存在、权限问题等,以确保程序的健壮性。
本资源“C#操作Excel表格.rar”提供了一种使用C#与Microsoft Excel进行交互的方法,允许开发者读取、写入和处理Excel数据。在实际业务中,这种功能非常常见,比如数据分析、报表生成或自动化办公流程。 C#操作Excel...
1. 错误处理:在操作Excel时,需要捕获可能出现的异常,如文件不存在、权限问题等。 2. 释放资源:使用完Excel对象后,记得使用`Marshal.ReleaseComObject`释放COM对象,并最终关闭工作簿和应用程序以避免内存泄漏。...
"C#合并EXCEL单元格"的主题涉及到如何使用C#编程语言操作Microsoft Excel文档,特别是针对那些需要将相同内容的单元格进行纵向合并的需求。下面将详细介绍这个主题,并提供一些关键知识点。 首先,你需要引入能够...
- **错误处理**: 捕获可能出现的文件读写错误,如文件不存在、权限问题等。 以上就是C#中导入Excel文件到ListView和导出ListView到Excel文件的基本步骤和技术要点。这个过程涉及到文件操作、数据处理和UI控件的使用...
下面我们将深入探讨使用C#和NPOI操作Excel的知识点: 1. **安装NPOI**:首先,你需要通过NuGet包管理器在你的C#项目中安装NPOI库。在Visual Studio中,可以右键点击项目,选择“管理NuGet程序包”,然后搜索并安装...
本主题聚焦于如何使用C#进行Excel文件的操作,这在数据分析、报告生成、数据导入导出等场景中非常常见。下面我们将深入探讨C#操作Excel文件的关键知识点。 首先,C#操作Excel文件主要通过以下三种方式: 1. **...
以下是关于EPPlus在C#中操作Excel的一些关键知识点: 1. **安装EPPlus**:你可以通过NuGet包管理器在你的C#项目中添加EPPlus。在Visual Studio中,右键点击解决方案资源管理器中的项目,选择“管理NuGet程序包”,...
具体操作是:控制面板 -> 管理工具 -> DCOM配置 -> Microsoft Excel 应用程序 -> 属性 -> 安全选项卡 -> 自定义 -> 添加 -> 给予“本地启动”和“本地激活”的权限。 以上就是使用C#通过Excel COM接口生成图片的...