网站经iis发布后,导出excel出问题

时间:2022-09-03 20:08:29
导出excel的代码是我在网上找的。在vs调试时可以用。

发布之后,就出现下面的问题:

检索 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 帐户,选中所需访问权限对应的框。

源错误: 


行 285:    public bool DataTableToExcel(System.Data.DataTable dt)
行 286:    {
行 287:        Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
行 288:
行 289:        Microsoft.Office.Interop.Excel.Workbook excelBook = excelApp.Workbooks.Add(Type.Missing);
 

源文件: f:\jinhuayuanPro\Admin\main\sqtz\renkou.aspx.cs    行: 287 

堆栈跟踪: 


[UnauthorizedAccessException: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失败,原因是出现以下错误: 80070005。]
   Admin_main_sqtz_unityBook.DataTableToExcel(DataTable dt) in f:\jinhuayuanPro\Admin\main\sqtz\renkou.aspx.cs:287
   Admin_main_sqtz_unityBook.tableTOexcel_Click(Object sender, EventArgs e) in f:\jinhuayuanPro\Admin\main\sqtz\renkou.aspx.cs:271
   System.Web.UI.WebControls.Button.OnClick(EventArgs e) +111
   System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument) +110
   System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +10
   System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13
   System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +36
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +1565

 


怎么回事啊。在网上也找了,没弄好。

5 个解决方案

#1


IIS和VS在同一台机器上吗?如果不是应该是COM组件没有注册的原因

#2


引用 1 楼  的回复:
IIS和VS在同一台机器上吗?如果不是应该是COM组件没有注册的原因

在同一机器上。

#3


通常会是组件的注册问题

#4


ASP.NET 未被授权访问所请求的资源。请考虑授予 ASP.NET 请求标识访问此资源的权限。ASP.NET 有一个在应用程序没有模拟时使用的基进程标识(通常,在 IIS 5 上为 {MACHINE}\ASPNET,在 IIS 6 上为网络服务)。如果应用程序正在通过 <identity impersonate="true"/> 模拟,则标识将为匿名用户(通常为 IUSR_MACHINENAME)或经过身份验证的请求用户。 

要将 ASP.NET 访问权限授予某个文件,请在资源管理器中右击该文件,选择“属性”,然后选择“安全”选项卡。单击“添加”添加适当的用户或组。突出显示 ASP.NET 帐户,选中所需访问权限对应的框

红字说得很清楚了,应该是权限问题吧。给文件夹加上ASP.NET的读写权限

#5


学习了:
http://www.cnblogs.com/luluping/archive/2010/11/29/1890992.html
有你需要的答案。

#1


IIS和VS在同一台机器上吗?如果不是应该是COM组件没有注册的原因

#2


引用 1 楼  的回复:
IIS和VS在同一台机器上吗?如果不是应该是COM组件没有注册的原因

在同一机器上。

#3


通常会是组件的注册问题

#4


ASP.NET 未被授权访问所请求的资源。请考虑授予 ASP.NET 请求标识访问此资源的权限。ASP.NET 有一个在应用程序没有模拟时使用的基进程标识(通常,在 IIS 5 上为 {MACHINE}\ASPNET,在 IIS 6 上为网络服务)。如果应用程序正在通过 <identity impersonate="true"/> 模拟,则标识将为匿名用户(通常为 IUSR_MACHINENAME)或经过身份验证的请求用户。 

要将 ASP.NET 访问权限授予某个文件,请在资源管理器中右击该文件,选择“属性”,然后选择“安全”选项卡。单击“添加”添加适当的用户或组。突出显示 ASP.NET 帐户,选中所需访问权限对应的框

红字说得很清楚了,应该是权限问题吧。给文件夹加上ASP.NET的读写权限

#5


学习了:
http://www.cnblogs.com/luluping/archive/2010/11/29/1890992.html
有你需要的答案。