`
hcmfys
  • 浏览: 347252 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

c# 操作Excel 权限问题

    博客分类:
  • c#
阅读更多
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

    种读取Excel方法 插入Excel数据 修改Excel的值 导出...2. 对Excel操作时,由于使用权限的不同,可能对表格的操作权限也不一样。EXCEL提供了保护工作表以及允许编辑单元格功能。相应的在C#中就可以对Excel表格进行操作

    c#操作excel实例,excel的iis权限设置

    c#操作excel实例,excel的iis权限设置

    C#中Excel操作权限

    2、内存或磁盘空间不足,Microsoft Office Excel 无法再次打开或保存任何文档。 ? 要想获得更多的可用内存,请关闭不再使用的工作簿或程序 ? 要想释放磁盘空间,请删除相应磁盘上不需要的文件。

    C#利用Excel生成图片

    C#下操作Excel COM接口,可以将不同类型的图(比如柱状图、线形图、叠加柱状图)根据数据生成在同一张图片上。 在跑的过程中,如果有COM报错,请检查DCOM下Excel组件的权限。

    C#+EXCEL导入数据库SQLserver 2005+

    本人的处女作,供初学者参考一下,顺便赚点积分,没有积分用了,呵呵 C#+EXCEL导入数据库SQLserver 2005+权限限制+分类查询+dategridview 删除编辑选中行

    C#配置office权限

    C#在iis上发布网站,从网站中导出excel需要配置office权限

    Csharp导出到EXCEL表格多sheet与打包软件

    9、文件、文件夹、注册表项和值的访问权限 - 搜索、下载并安装运行环境 - 在模块和组件中组织您的应用程序 - 使用自定义操作扩展安装进程 - 自定义安装用户界面 - 更多支持的功能: 1、用于软件升级的更新器 2、...

    C#使用简单三层实现获取本地计算机硬件信息以及使用ADO.net操作数据库、用户权限控制、条件筛选、Excel导出、单例模式等功能

    2、ADO.NET对数据库的操作 3、单例模式 4、C#中的API获取计算机硬件信息 5、用户权限控制 6、NPOI导出数据到Excel 7、数据的条件筛选 ...... 这个demo比较适合新手参考、用到的知识点比较广、希望对新手有一点的帮助

    c# 解决IIS写Excel的权限问题

    使用以上方法必须对dcom进行配置,给用户使用office的权限

    C#用户权限控制架构,可以控制到类

    Lm.Common.Excel Excel2003的读取与生成 Lm.Common.Excel.OpenXml Excel2007、2010的读取和生成 Lm.Common.ExtensionMethods 一些使编码更加方便的扩展方法 Lm.Common.Security.Cryptography 加密 Lm....

    C#经典项目经验总结.doc

    解决IIS写Excel的权限问题 脚本发生错误 res://ieframe.dll/aboutXP.dlg 有关一个.aspx文件中放置多个Form的疑问 . . . 关于ASPNET用户的权限 删除服务器的文件夹后,session就丢失的问题 ASP.NET 状态服务 及 ...

    导出Excel的C#实现帮助类

    4. 共享和协作:Excel支持多用户同时编辑同一个工作簿,并提供版本控制和共享权限管理。它还可以与其他Microsoft Office应用程序(如Word和PowerPoint)无缝集成,方便用户在不同的文档之间进行数据交换和共享。 5....

    C#上位机开发源码 上位机项目源代码 采用基于RS485通讯总线的ModbusRtu协议,支持用户权限管理、sqlite数据库、

    C#上位机开发源码 上位机项目源代码 采用基于RS485通讯总线的ModbusRtu协议,支持用户权限管理、sqlite数据库、实时曲线、历史曲线、历史报表、导出Excel、主界面布局可调带记忆等功能

    导出excel错误处理

    执行当前 Web 请求期间,出现未处理的异常。请检查堆栈跟踪信息,以了解有关该...主要是web上传到服务器,然后读取excel中数据并保存到数据库的过程,服务器端会存在c#是否有权限使用excel com组件的问题! 导出也是。

    c# .net core 3.1 好用的通用后台管理 前后端分离框架

    前后端分离框架,基于.NET5/.NET6实现的通用权限管理平台。整合最新技术高效快速开发,前后端分离模式,开箱即用。 代码量少、学习简单、通俗易懂、功能强大、易扩展、轻量级,让web开发更快速、简单高效(从此告别...

    快速开发框架C#源码完全开源版 基于ASP.NET MVC+EF6+Bootstrap框架等

    1、一套基于ASP.NET MVC+EF6+Bootstrap开发出来的框架,源代码完全开源,可以帮助你解决C#以及.NET项目68%的重复工作,让开发人员远离加班。 2、使用ApacheLicense2.0协议,采用主流框架,容易上手,简单易学,学习...

    C#学生信息数据库管理系统.pdf

    其中学生信息管理对大数据 量要求较高, 而教师排课系统由于需要十分专业的算法并且系统需求不断的变化, 因此在实 际应用时,往往会遇到很大的问题,需要进一步研究,目前一般的学校管理系统都包含了学 生信息管理...

    C#开发实例大全(基础卷).软件开发技术联盟(带详细书签) PDF 下载

    主要内容有C#开发环境的使用、C#语言基础应用、字符串处理技术、数组和集合的使用、面向对象编程技术、...C#与Word互操作、高效应用Excel、基本图形绘制、图像处理技术、常用图表应用、动画处理技术、音频与视频控制...

Global site tag (gtag.js) - Google Analytics