检索 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 帐户,选中所需访问权限对应的框。源错误: 
行 592:        _Workbook xBk;
行 593:        _Worksheet xSt = null;
行 594:        excel = new ApplicationClass();
行 595:        xBk = excel.Workbooks.Add(true);
行 596:
 源文件: d:\kejijuusing\kejiju\App_Code\WebHelper.cs    行: 594

解决方案 »

  1.   

    在网上查了很多资料,大多是这样解决的
    (1)运行dcomcnfg.exe。
    (2)组件服务→计算机→我的电脑→DCOM配置。
    (3)右击Microsoft Excel应用程序→属性→安全→启动和激活权限→自定义→编辑。
    (4)添加ASPNET用户。====================================
    可我照做了还是不成功!我的系统是xp。
    ====================================有一种方法是在web.config中添加
    <identity   impersonate="true"   userName="yourmachine\administrator"   password="yourpassword"></identity> 
    试了能成功!但感觉这样安全性可能不太好。
      

  2.   

    <identity  impersonate="true"  userName="yourmachine\administrator"  password="yourpassword"> </identity> 
    就这种能用。其它的不能用
      

  3.   

    有开源导出excel的控件
    一般不建议用微软的office组件,不太好(不太容易释放,权限,资源占用问题)
    例如 myxls 很好的导出excel控件
      

  4.   

    我是将数据(比如说Gridview里的数据,Dataset/Datetable)先专程XML格式,然后将XML导出到Excel,这样也许可以避免错误,而且速度还很快。