请教各位,我想把gridview中的数据导出到excel中,我的做法是,先将数据以excel的形式保存到服务器端,然后再从客户端将该文件下载下来。可以出以下报错:
---------------------------------------------------------------------------------------------------------------------------------
检索 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 帐户,选中所需访问权限对应的框。
源错误:
行 486: GVTotalTable.DataBind();
行 487:
行 488: Application excel = new Application();
行 489: if (excel == null)
行 490: {
---------------------------------------------------------------------------------------------------------------------------
下面是我的代码,如果是在我本机上直接执行程序,则可以实现此功能,但一上传到iis服务器中,客户端运行就会报错.
Application excel = new Application();
if (excel == null)
{
return;
}
excel.Visible =false;
Workbooks xBk = excel.Workbooks;
_Workbook workbook = xBk.Add(XlWBATemplate.xlWBATWorksheet);
Sheets xSt = workbook.Worksheets;
_Worksheet worksheet = (_Worksheet)xSt.get_Item(1);
object m_objOpt = System.Reflection.Missing.Value;
DataSet ds = new DataSet();
int Rows = 0;
int Cols = 0;
ds = this.Search(); //获取要导出的数据
Rows = ds.Tables[0].Rows.Count;
Cols = ds.Tables[0].Columns.Count;
object[,] array = new object[Rows, Cols];
string[] titlearray = new string[31];
Range range2 = worksheet.get_Range("A1", "AC1");
titlearray[0] = "物料申请日期"; titlearray[1] = "工程定单号"; titlearray[2] = "项数"; titlearray[3] = "采购定单号";
titlearray[4] = "货号"; titlearray[5] = "SAP码"; titlearray[6] = "货名规格"; titlearray[7] = "订单描述";
titlearray[8] = "需求量"; titlearray[9] = "单位"; titlearray[10] = "申请科室"; titlearray[11] = "申购人";
titlearray[12] = "送货地点"; titlearray[13] = "要求到料日期"; titlearray[14] = "回复货期"; titlearray[15] = "采购员";
titlearray[16] = "PO/NO"; titlearray[17] = "供应商编号"; titlearray[18] = "供应商名称"; titlearray[19] = "入仓时间";
titlearray[20] = "入仓数量"; titlearray[21] = "欠料数量"; titlearray[22] = "领用单位"; titlearray[23] = "领用人";
titlearray[24] = "领用日期"; titlearray[25] = "领用数量"; titlearray[26] = "退料单位"; titlearray[27] = "退料人";
titlearray[28] = "退料日期"; titlearray[29] = "退料数量"; titlearray[30] = "库存";
Range range = worksheet.get_Range("A2", worksheet.Cells[Rows, Cols]);
for (int i = 0; i < Rows; i++)
{
for (int j = 0; j < Cols; j++)
{
array[i, j] = ds.Tables[0].Rows[i][j];