首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > asp.net >

System.UnauthorizedAccessException: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046} 的组件时失

2014-05-31 
还是导出excel的问题请教各位,我想把gridview中的数据导出到excel中,我的做法是,先将数据以excel的形式保

还是导出excel的问题
请教各位,我想把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];


  }
  }
  range2.Value2 = titlearray;
  range.Value2 = array;

  string excelName = System.DateTime.Now.Year.ToString() + System.DateTime.Now.Month.ToString() + System.DateTime.Now.Day.ToString() + System.DateTime.Now.Minute.ToString() + System.DateTime.Now.Second.ToString();
  string updatdPath = HttpContext.Current.Server.MapPath(""); //服务器路径
  string pathAll = updatdPath + "\\" + excelName+".xlw";

  try
  {
  workbook.SaveAs(pathAll, m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt, XlSaveAsAccessMode.xlNoChange, m_objOpt, m_objOpt, m_objOpt, m_objOpt, m_objOpt);
  workbook.Close(m_objOpt, pathAll, m_objOpt);
  xBk.Close();
  Process[] myProcesses = Process.GetProcesses();
  foreach (Process p in myProcesses)
  {
  if (p.ProcessName == "excel")
  {
  p.Kill();
  }
  }
   
  }
  catch (Exception ex)
  {
  BLL.UtilClew.ErrorTip(this, ex.Message);
  }
  FileStream myFile = System.IO.File.OpenRead(pathAll);
  BinaryReader br = new BinaryReader(myFile);
  Response.AddHeader("Accept-Ranges", "bytes");
  Response.Buffer = false;
  long fileLength = myFile.Length;
  long startBytes = 0;

  int pack = 10240; //10K bytes
  int sleep = 200; //每秒次 即*10K bytes每秒
  string[] range3;
  //int sleep =Math.Floor(10) + 1;
  if (Request.Headers["Range"] != null)
  {
  Response.StatusCode = 206;
  range3 = Request.Headers["Range"].Split(new char[] { '=', '-' });
  startBytes = Convert.ToInt64(range3[1]);
  }
  Response.AddHeader("Content-Length", (fileLength - startBytes).ToString());
  if (startBytes != 0)
  {
  Response.AddHeader("Content-Range", string.Format(" bytes {0}-{1}/{2}", startBytes, fileLength - 1, fileLength));
  }
  Response.AddHeader("Connection", "Keep-Alive");
  Response.ContentType = "application/octet-stream";
  Response.AddHeader("Content-Disposition", "attachment;filename=" + HttpUtility.UrlEncode(pathAll, System.Text.Encoding.UTF8));

  br.BaseStream.Seek(startBytes, SeekOrigin.Begin);
  int maxCount = (int)Math.Floor((Convert.ToDecimal(fileLength - startBytes)) / pack) + 1;
  for (int i = 0; i < maxCount; i++)
  {
  if (Response.IsClientConnected)
  {
  Response.BinaryWrite(br.ReadBytes(pack));
  Thread.Sleep(sleep);
  }
  else
  {
  i = maxCount;

  }
  }
   
  myFile.Close();
  System.IO.File.Delete(pathAll);
  br.Close();


   
  Response.End();


[解决办法]
那我还是送上这个帖子...
不推荐用 Application excel = new Application(); 呵呵~

http://topic.csdn.net/u/20071015/12/a9c49cb4-a83e-44ae-bdca-5b942b920003.html
[解决办法]
DLL的问题,你要保证在IIS中有EXCEL生成的相关DLL
因为客户端中不一定会有
[解决办法]
权限配置问题

以windows2003为例

打开"控制面板"->"管理工具"->"组件"

在左侧的目录树中,依次展开"组件服务"->"计算机"->"我的电脑"->"DCOM配置"

找到"Microsoft Excel应用程序",单击右键,选择"属性"

打开"Microsoft Excel应用程序 属性" 对话框

如果无法操作到这一步,请检查是否是系统问题

单击"安全"选项卡

1.将"启动和激活权限"设置为"自定义",点击编辑,给Users用户添加权限
2.将"访问权限"设置为"自定义",点击编辑,给Users用户添加权限

单击"应用"

配置完毕

声明:该配置方式中,给Users用户组添加权限,实际上是扩大了权限,如果对安全要求较高,在实现功能之后,请参考相关文章缩小权限范围
[解决办法]
需要确认服务器上正确的安装了EXCEL,并配置了DCOM
[解决办法]
WEBFORM倒出EXCEL文件不用那么的复杂了,直接的把数据表生成一个HTML表格,可以添加简单样式!
写出时让其格式为X-EXCEL就可以了,下载就是EXCEL文件了!
RESPONSE.write(strhtmTable ttt);
这样不知道可以不可以搞定了1
希望对你有帮助了!

热点排行