导出excel失败,提醒提示加载类型库/DDL出错

www.MyException.Cn   发布于:2012-08-17 02:08:34   浏览:1538次
 

导出excel失败,提示提示加载类型库/DDL出错 ?
我想做导出数据到excel,引用Excel的动态链接库Microsoft Excel 11.0 Object Library(2003版本的),并在程序里添加了

using Excel; 在我自己的笔记本上编译通过并成功导出了Excel,但是到公司的机器上不行了,同样的操作却引用不上Excel这个命

名空间了,我原先自己笔记本上做好的程序拷贝过来,编译通过,执行时出错,提示:无法将类型为"Excel.ApplicationClass"的

COM对象强制转换为接口类型"Excel.Application".此操作失败的原因是对IID为"{000208D5-0000-0000-C000-000000000046}"的接

口的COM组件调用QueryInterface,因一下错误而失败:

加载类型库/DDL时出错.(异常来自 HRESULT:0X8029C4A(TYPE_E_CANTLOADLIBRARY))

都是装的vs2008,但我感觉好像是公司的vs里少什么类型库,但是又不知道问题在哪、 求教.

如有满意答案或能帮助解决了问题的,追加50分,谢谢!
------解决方案--------------------
这个问题,正好我也碰到过,而且貌似很多人也碰到过这个问题.
其实这个主要就是 服务器上没有安装office,或者安装了但是没有相关权限.给你一个参考的解决办法.

一. 如果采用Office 组件进行Excel导出, 服务器上必须安装对应版本的Office(如你开发使用的Office2003,则服务器也需要安装Office2003,当然,如果仅仅是导出Excel 则只需安装Office Excel), 没有安装Office是不能够进行导出的.
二. 对于出现类似于 “错误代码: 检索 COM 类工厂中 CLSID 为{00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005。” 错误,其原因基本上是由于权限不够导致的,一般的解决步骤如下:(以下解决方案适用于 WinXp,2003,2008, 包括64位系统, 我所采用的Office 版本为2003)
1:在”开始”->”运行”中输入dcomcnfg.exe启动”组件服务”
2:依次双击”组件服务”->”计算机”->”我的电脑”->”DCOM配置”
3:在”DCOM配置”中找到”Microsoft Excel 应用程序”,在它上面点击右键,然后点击”属性”,弹出”Microsoft Excel 应
用程序属性”对话框
特别注意: 在win2008 64位系统中, 默认是看不到 “Microsoft Excel 应用程序” 这一项的,需要先在 “开始”->”运行”
里输入 “mmc -32″ (不要引号) 回车,在弹出的窗口中,
a.在第一个菜单(File)中选择 “添加/删除组件(Add/Remove Snap)”
b.添加”组件服务(Component Services)
c.然后可以在 组件服务(Component Services)下找到 “Microsoft Excel 应用程序” 项
d.此后的操作同 32位操作系统
4:点击”标识”标签,选择”交互式用户”
5:点击”安全”标签,在”启动和激活权限”上点击”自定义”,然后点击对应的”编辑”按钮,在弹出的”安全性”对话框中填加
一个”NETWORK SERVICE”用户(注意要选择本计算机名),并给它赋予”本地启动”和”本地激活”权限.
6:依然是”安全”标签,在”访问权限”上点击”自定义”,然后点击”编辑”,在弹出的”安全性”对话框中也填加一个”NETWORK
SERVICE”用户,然后赋予”本地访问”权限.
这样,我们便配置好了相应的Excel的DCOM权限.
注意:这是在WIN2003上配置的,在2000,xp上,是配置ASPNET用户
一般通过以上步骤就能解决问题,当然如果您的问题还没解决,可以参考以下资料:
1) 查看你的Web.config 中是否有 <identity impersonate=”true”/> 这一项,如果有,请删除
这段话的目的是为每一个请求进行客户端模拟,按照提示信息中的解释,由于没有设置Username,
所以当前执行的用户是IUSR_MACHINENAME,而该用户是没有操作Excel组件的权限
如果您需要添加指定用户的权限,你可以
<identity impersonate=”true”  userName=”登录名”  password=”密码 “/>
2)如果交互式用户设置后出现错误8000401a,可取消交互式用户,指定为administratr,可暂时解决此问题。
注意:采用以上设置后,打开Excel可能会出现“无法使用对象引用或链接”,并且不能进行单元格粘贴。
原因不明,取消设置后即可消失。
3)如果同时存在多个Office版本,请确认下默认打开Excel的版本是哪个,如果有误则可以采用如下方法重新注册
开始 -> 运行 -> 输入excel2003(2007类似)的安装路径,
例如 “C:\Program Files\Microsoft Office\OFFICE11\excel.exe” /regserver
注意/符号前面有一个空格,其中”C:\Program Files\Microsoft Office\OFFICE11\excel.exe”
是excel2003的安装程序的路径,参数regserver表示注册的意思
4)如果出现”不能设置类PageSetup的Orientation属性”的错误,检查下服务器上是否安装了打印机,如果没有
请安装一个(可以是虚拟打印机,本地)
5)对于64位系统如果还有问题,尝试下
在 C:\Windows\SysWOW64\config\systemprofile\下创建Desktop文件夹
然后提升应用池权限试试.

导出excel失败,提醒提示加载类型库/DDL出错的更多相关文章

  1. 导出excel失败,提示提示加载类型库/DDL出错

    首先,这里提供的解决办法仅适用于出现如下异常的情况:无法将类型为“Microsoft.Office.Interop.Excel.ApplicationClass”的 COM 对象强制转换为接口类型“M ...

  2. 使用NPOI将数据库里信息导出Excel表格并提示用户下载

    使用NPOI进行导出Excel表格大家基本都会,我在网上却很少找到导出Excel表格并提示下载的 简单的代码如下 //mvc项目可以传多个id以逗号相隔的字符串 public ActionResult ...

  3. ASP.NET导出Excel(利用NPOI和EPPlus库,无需安装Office)

    网上提供了很多Asp.net中操作Excel的方法,其中大部分是调用微软的Office组件,下面提供三个无须安装Office即可从Asp.net输出Excel的方法. 1 简单方法 //下面代码输出的 ...

  4. 谷歌浏览器导出excel失败问题解决(网上都没解决)

    java poi导出excel报了网络错误,信息已经写回到chrome浏览器(IE/FF均无此问题).如下所示: 从chrome的network大小部分也可以看出是正确的. 网上很多答案说将file. ...

  5. 关于asp.net mvc4 在IE8下 导出excel失败的解决办法

    在使用FileResult向浏览器输出文件时(pdf,excel等),通常这样做: byte[] fileContents = Encoding.UTF8.GetBytes(sbHtml.ToStri ...

  6. 导入导出Excel工具类ExcelUtil

    前言 前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出 本项目的持久化层用的是JPA(底层用hibe ...

  7. 导入导出Excel的Java工具类ExcelUtil

    在编写ExcelUtil之前,在网上查了一些资料.java中用来处理Excel的第三方开源项目主要就是POI和JXL.poi功能强大,但是比较耗资源,对于大数据量的导入导出性能不是太好:jxl功能简单 ...

  8. 项目笔记:导出Excel功能

    1.前台这块: var ids=""; $.post("${basePath}/assets/unRegDeviceAction_getDeviceIds.do" ...

  9. jxl java工具类,导出excel,导入数据库

    1: 引入jxl jar 我使用的为maven管理, <!--Excel工具--> <dependency> <groupId>net.sourceforge.je ...

随机推荐

  1. JS iframe元素和父页面元素互访

    说明:以下内容来自互联网 [1]子页面取得父页面的dom对象   parent.window.$('#id').val("");   [2]父页面取得子页面的对象   $(wind ...

  2. context:component-scan扫描使用的use-default-filters

    如下方式可以成功扫描到@Controller注解的Bean,不会扫描@Service/@Repository的Bean. <context:component-scan base-package ...

  3. 使用事件捕获实时捕获img是否加载完毕, 实现iframe内容高度自动适应

    如何判断在html中图片加载完毕呢? 给img图片加onload事件呗. 如何判断一个界面中所有的图片加载完毕呢? 给所有的图片加上onload事件呗. 如果有1000张图片那要怎么绑定事件呢? 我们 ...

  4. Jquery-pagination.js分页处理

    首先提供pagination.js的插件源码 /** * This jQuery plugin displays pagination links inside the selected elemen ...

  5. java类生命周期详细解析

    (一)详解java类的生命周期 引言 最近有位细心的朋友在阅读笔者的文章时,对java类的生命周期问题有一些疑惑,笔者打开百度搜了一下相关的问题,看到网上的资料很少有把这个问题讲明白的,主要是因为目前 ...

  6. 虚拟机NAT模式无法上网问题的解决办法

    在使用CentOS虚拟机时,出现了无法上网的情况,使用主机ping虚机地址可以ping通,而虚机ping不通主机,同时虚机也无法ping通其他的网址或ip,显示内容为Network is unreac ...

  7. bzoj4204: 取球游戏

    好神啊.. 首先递推随便yy一下就行了 然后发现可以用矩阵优化,不过显然是n^3logk的,不资磁 于是就有了性质,这个转移矩阵显然是一个循环矩阵(并不知道) 循环矩阵乘循环矩阵还是循环矩阵 然后就可 ...

  8. wamp中修改后mysq数据库l闪退无法登陆解决办法

    WampServer安装后密码是空的,   修改一般有三种方式:   一是通过phpMyAdmin直接修改:   二是使用WAMP的MySql控制台修改.     三是重置密码    第一种:   1 ...

  9. matplotlib 柱状图、饼图;直方图、盒图

    #-*- coding: utf-8 -*- import matplotlib.pyplot as plt import numpy as np import matplotlib as mpl m ...

  10. BZOJ 2080: [Poi2010]Railway 双栈排序

    2080: [Poi2010]Railway Time Limit: 10 Sec  Memory Limit: 259 MBSubmit: 140  Solved: 35[Submit][Statu ...