`
czt004
  • 浏览: 1538 次
  • 性别: Icon_minigender_1
  • 来自: 青岛
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

windows7 IIS6 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,

 
阅读更多
 
.net导出excel中出错 (我用方法二解决的)


说明: 执行当前 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 帐户,选中所需访问权限对应的框。

主要是web上传到服务器,然后读取excel中数据并保存到数据库的过程,服务器端会存在c#是否有权限使用excel com组件的问题! 导出也是。


具体解决方法如下:


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

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

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

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

用程序属性"对话框

5:点击"标识"标签,选择"交互式用户"

6:点击"安全"标签,在"启动和激活权限"上点击"自定义",然后点击对应的"编辑"按钮,在弹出的"安全性"对话框中填加

一个"NETWORK SERVICE"用户(注意要选择本计算机名),并给它赋予"本地启动"和"本地激活"权限.

7:依然是"安全"标签,在"访问权限"上点击"自定义",然后点击"编辑",在弹出的"安全性"对话框中也填加一个"NETWORK

SERVICE"用户,然后赋予"本地访问"权限.

这样,我们便配置好了相应的Excel的DCOM权限.

注意:这是在WIN2003上配置的,在2000,xp上,是配置ASPNET用户

由于EXCEL是在服务器上打开的,所以应该写一个把导出数据保存在服务器上,然后再传递给客户端的方法,最后每次调

用这个功能的时候再删除以前在服务器上所生成的所有Excel

=================================================

以上是网上流传的办法

我的开发环境 windows7 IIS6 VS2008

在windows7 根本无法配置ASPNET用户,只能选择添加NETWORK用户跟WIN2003一样

这样还不行 还要在IIS6中设置应用程序池 打开IIS6->应用程序池->DefaultAppPool(我使用的.net2.0)右键->高级设置->找到 标识改为NetworkService 确定重启后搞定
分享到:
评论

相关推荐

    检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件问题整理

    问题 1:错误:0x80040154 或 8000401a 错误信息:检索 COM 类工厂中 CLSID 为 {000209FF-0000-0000-C000-000000000046} 的组件失败,原因是出现以下错误:80040154 没有注册类(异常来自 HRESULT:0x80040154(REGDB_...

    【Excel】Retrieving the COM class factory for component with CLSID

    在使用ASP .NET应用程序操作Excel、Word等Office软件时,有时会在IIS服务器上部署应用过程中遇到错误:“Retrieving the COM class factory for component with CLSID {00024500-0000-0000-C000-000000000046}”。...

    检索 COM 类工厂中 CLSID 为 {10020200-E260-11CF-AE68-00AA004A34D5} 的组件时失败注册SQLDMO文件

    首先将msvcr71.dll, SQLDMO.DLL, Resources\2052\sqldmo.rll,Resources\1033\sqldmo.rll 拷贝到C:\Program Files\Microsoft SQL Server\80\Tools\Binn目录,,在运行中输入 regsvr32 "C:\Program Files\Microsoft ...

    Windows2008Server IIS 7.0配置DCOM

    在本案例中,该错误发生在尝试检索COM类工厂中CLSID为{000209FF-0000-0000-C000-000000000046}的组件(对应于Word)时,这表明权限配置可能存在问题。 2. **操作系统和IIS版本**: 使用的是Windows Server 2008非...

    sqlserver导出excel文件出错解决方案

    6. **重置 IIS 或重启计算机**: - 在某些情况下,可能需要重置 Internet Information Services (IIS) 或者重新启动计算机以使更改生效。 7. **更新组件**: - 最后,考虑更新 SQL Server、Office 或操作系统到...

    ASP.NET操作Word的IIS权限设置

    ASP.NET账号在默认情况下是没有权限操作Microsoft Office对象的,如果不进行权限的配置,代码会抛出类似以下的异常: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现...

    Asp.net操作Excel的权限问题

    &gt; 检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:80070005。 这个错误码通常表示**拒绝访问**,意味着当前应用程序没有足够的权限去访问所需的COM组件。这可能...

    导出excel错误处理

    进一步分析异常描述可以发现,当尝试通过COM接口访问一个特定CLSID( `{00024500-0000-0000-C000-000000000046}`)所代表的组件时,出现了错误代码`80070005`。这个错误代码通常与权限不足有关,意味着当前应用程序...

    ASP.Net Web应用程序与EXCEL交互时遇到的权限问题

    System.UnauthorizedAccessException: 检索COM类工厂中CLSID为{00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现以下错误:80070005。 ASP.NET未被授权访问所请求的资源。请考虑授予ASP.NET请求标识...

    由于以下错误,检索具有CLSID {XXXX}的组件的COM类工厂失败:80040005

    当我的Web服务试图通过.net Web服务实用地打开MS Word文档时,出现以下错误。 当我通过Visual Studio运行Web服务时,它工作正常,但是当我在IIS 7上部署Web服务时,出现错误检索COM类工厂用于...

    .Net导出word服务器配置

    例如,当尝试调用Word对象时,可能会收到类似于“检索COM类工厂中CLSID为{000209FF-0000-0000-C000-000000000046}的组件时失败”的错误。这是由于.NET应用程序试图访问32位COM组件(Word),但服务器默认是以64位...

    ASP3.0教程中文版-5

    4. **其他组件**:包括自定义组件、第三方组件以及Windows服务或产品提供的组件,如Windows Scripting Host。 #### VBScript和JavaScript脚本对象详解 脚本运行期库中最为核心的是三个对象:Dictionary、...

Global site tag (gtag.js) - Google Analytics