ASP.NET访问Excel 失败的解决方法(错误号:80070005,8000401a)

用asp.net把值写入Excel在本地测试经过,而后提交服务器后总是写入不成功 并提示错误: Retrieving the COM class factory for component with CLSID {00024500-0000-0000-C000-000000000046} failed due to the following error: 80070005.
在网络上查找了许多资料,原来是对于用户来讲,对服务器上的文件的操做权限不够所引发的错误,要配置DCOM
具体配置方法以下:

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

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

3:依次双击"组件服务"->"计算机"->"个人电脑"->"DCOM配置"网络

4:在"DCOM配置"中找到"Microsoft Excel 应用程序",在它上面点击右键,而后点击"属性",弹出"Microsoft Excel 应用程序属性"对话框asp.net

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

6:点击"安全"标签,在"启动和激活权限"上点击"自定义",而后点击对应的"编辑"按钮,在弹出的"安全性"对话框中填加一个"NETWORK SERVICE"用户(注意要选择本计算机名),并给它赋予"本地启动"和"本地激活"权限.spa

7:依然是"安全"标签,在"访问权限"上点击"自定义",而后点击"编辑",在弹出的"安全性"对话框中也填加一个"NETWORK SERVICE"用户,而后赋予"本地访问"权限.
好不容易这个问题解决了,接下来又出现8000401a错误!
若是是8000401a错误:.net

右键打开属性对话框,点击"标识"选项卡, component

点"下列用户",把管理员的用户密码正确填写进去... it

点击"安全"选项卡, class

依次把"启动和激活权限","访问权限","配置权限",都选择为自定义,

而后依次点击它们的编辑,把NETWORK SERVICE添加进去,并加入本地的读写权限...

 

最后,咱们还要给所在盘的安全设置修改权限,一样也是属性--安全--添加NETWORK SERVICE,给它修改权限。

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

 

总结:

1。只要加NETWORK SERVICE的权限就能够了,没必要加everyone;

2。若是选择“交互式用户”还不行,必须选择“下列用户”,而后填入管理员的用户名和密码;

3。还要设置盘符的“安全”选项卡,在X盘上右击-属性-安全,一样添加NETWORK SERVICE用户名,并给它修改的权限,这样才最后能够用。

相关文章
相关标签/搜索