欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2023-12-03 15:40:46
具体配置方法如下: 1:在服务器上安装office的excel软件. 2:在"开始"->"运行"中输入dcomcnfg.exe启动"组件服务" 3:依次双击"组件服务...
具体配置方法如下:

1:在服务器上安装office的excel软件.
2:在"开始"->"运行"中输入dcomcnfg.exe启动"组件服务"
3:依次双击"组件服务"->"计算机"->"我的电脑"->"dcom配置"
4:在"dcom配置"中找到"microsoft excel 应用程序",在它上面点击右键,然后点击"属性",弹出"microsoftexcel 应用程序属性"对话框
5:点击"标识"标签,选择"交互式用户"
6:点击"安全"标签,在"启动和激活权限"上点击"自定义",然后点击对应的"编辑"按钮,在弹出的"安全性"对话框中填加一个"networkservice"用户(注意要选择本计算机

名),并给它赋予"本地启动"和"本地激活"权限.
7:依然是"安全"标签,在"访问权限"上点击"自定义",然后点击"编辑",在弹出的"安全性"对话框中也填加一个"networkservice"用户,然后赋予"本地访问"权限.
这样,我们便配置好了相应的excel的dcom权限.
注意:我是在win2003上配置的,在2000上,是配置aspnet用户

若不进行配置会出现错误
检索 com 类工厂中 clsid 为 {00024500-0000-0000-c000-000000000046}的组件时失败,原因是出现以下错误: 80070005。
原因是用户没有使用excel的权限。
导出到word同样要配置使用word的权限。


失败,原因是出现以下错误: 80070005
症状:
owordapplic = new word.application
当程序运行到这句时出现下面的错误:
检索 com 类工厂中 clsid 为 {000209ff-0000-0000-c000-000000000046}的组件时失败,原因是出现以下错误: 80070005。
owordapplic = new word.application
当程序运行到这句时出现下面的错误:
检索 com 类工厂中 clsid 为 {000209ff-0000-0000-c000-000000000046}的组件时失败,原因是出现以下错误: 80070005。
解决方法一:
控制面板-》管理工具-》组件服务-》计算机-》我的电脑-》dcom配置-》找到microsoft word文档
之后
单击属性打开此应用程序的属性对话框。
2. 单击标识选项卡,然后选择交互式用户。
3.单击"安全"选项卡,分别在"启动和激活权限"和"访问权限"组中选中"自定义",然后
自定义->编辑->添加asp.net账户和iuser_计算机名

* 这些帐户仅在计算机上安装有 iis 的情况下才存在。
13. 确保允许每个用户访问,然后单击确定。
14. 单击确定关闭 dcomcnfg。

解决方法二:
如果上述方法不能解决问题,就应该是权限问题,请尝试用下面的方法:
在web.config中使用身份模拟,在<system.web>节中加入 <identity impersonate="true" username="你的用户名"password="密码"/>
</system.web>

<identity impersonate="true" username="你的用户名"password="密码"/>
此处我用的超级用户测试的--通过