日期:2014-05-17  浏览次数:20505 次

检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 800
说明: 执行当前 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 帐户,选中所需访问权限对应的框。

源错误: 


行 37: public void Open(string FileName)//打开一个Excel文件
行 38: {
行 39: app = new Excel.Application();
行 40: app.Visible = false;
行 41: 
 

源文件: D:\lzy\SafetyEngineer.root\SafetyEngineer\DocumentReport\ExcelModule.cs 行: 39 

堆栈跟踪: 


[UnauthorizedAccessException: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005。]
  DocumentReport.ExcelModule.Open(String FileName) in D:\lzy\SafetyEngineer.root\SafetyEngineer\DocumentReport\ExcelModule.cs:39
  RegSafetyEngineer.Manage_Report_RegUnitsCase.ExportToExcel(DataTable dtUnitsInfo) in D:\lzy\SafetyEngineer.root\SafetyEngineer\RegSafetyEngineer\manage\Report\RegUnitsCase.aspx.cs:263
  RegSafetyEngineer.Manage_Report_RegUnitsCase.btnExport_Click(Object sender, EventArgs e) in D:\lzy\SafetyEngineer.root\SafetyEngineer\RegSafetyEngineer\manage\Report\RegUnitsCase.aspx.cs:255
  System.Web.UI.WebControls.Button.OnClick(EventArgs e) +105
  System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument) +107
  System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +7
  System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +11
  System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +33
  System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +5087


在本机调试没有任何问题,(F5dbug没有任何问题),但是编译完发布到本机的IIS上开始报这个错
只要帮忙解决,分数全部给出
 


--------------------------------------------


------解决方案--------------------
要将 ASP.NET 访问权限授予某个文件,请在资源管理器中右击该文件,选择“属性”,然后选择“安全”选项卡。单击“添加”添加适当的用户或组。突出显示 ASP.NET 帐户,选中所需访问权限对应的框。

这边错误不是很明显嘛,你就按照它的方法做就行了,这种是权限的问题,你把它开放出来就可以了
------解决方案--------------------
首先确认服务器上是否安装了excel组件,如安装请参考
------解决方案--------------------
这种情况下 我遇到过,一般是你调用的那个组件缺少dll支持,查看依赖看下!








泰安房产网
------解决方案--------------------
呵呵,我刚解决了这个问题
首页是,你服务器上得装office里的EXCEL
然后,给够权限
启用就可以了。
------解决方案--------------------
探讨
配置DCOM

具体配置方法如下:

1:在服务器上安装office的Excel软件.

2:在"开始"->"运行"中输入dcomcnfg.exe启动"组件服务"

3:依次双击"组件服务"->"计算机"->"我的电脑"->"DCOM配置"

4:在"DCOM配置"中找到"Microsoft Excel 应用程序",在它上面点击右键,然后点击"属性",弹出"Microsoft ……

------解决方案--------------------
没有操作权限
XP COM组件中添加aspnet操作权限
SERVER2003 net work操作权限
在"开始"->"运行"中输入dcomcnfg.exe启动"组件服务"
依次双击"组件服务"->"计算机"->"我的电脑"->"DCOM配置"