ASP.NET 2.0实现类似QQ邮箱中‘HTML方式查看’功能查看Office文件

我们在做一些系统的 下载模块 或者 内部邮箱 的时候,有些使用系统的人可能并没有 安装 office,但是又急需查看附件的内容甚至图片等等,下载安装一个Office又不大现实(时间要求紧?在某个网吧?在朋友家里?),那么如何查看一些常用的附件呢?

其实QQ邮箱有个功能很好,它可以以 HTML方式查看 Office文件,例如Word文档、Excel表格已经PowerPoint幻灯片等,这个功能有很多实现的办法,例如使用SPS就是办法之一,但是其实大部分时候,我们用不到SPS,或者由于正版软件太贵了,那如何使用ASP.NET 2.0(C#)来实现这个功能?

注意:以下代码在vs2008,office2007,windowsxp下 测试 通过,项目需要添加Excel 12、Word12、PowerPoint12、Office12 四个com引用
  1.         /// <summary>
  2.         /// 将PPT文件转换成HTML格式
  3.         /// </summary>
  4.         /// <param name="PptFilePath">PPT文件路径</param>
  5.         public static void PptToHtmlFile(string PptFilePath)
  6.         {
  7.             Microsoft.Office.Interop.PowerPoint.Application ppt = new Microsoft.Office.Interop.PowerPoint.Application();
  8.             Microsoft.Office.Interop.PowerPoint.Presentation pptFile = null;
  9.             try
  10.             {
  11.                 //获得html文件名
  12.                 string htmlFileName = PptFilePath.Substring(0, PptFilePath.LastIndexOf(".")) + ".html";
  13.                 //打开一个ppt文件
  14.                 pptFile = ppt.Presentations.Open(PptFilePath, Microsoft.Office.Core.MsoTriState.msoTrue, 
  15.                     Microsoft.Office.Core.MsoTriState.msoCTrue, Microsoft.Office.Core.MsoTriState.msoFalse);
  16.                 //转换成html格式
  17.                 pptFile.SaveAs(htmlFileName, Microsoft.Office.Interop.PowerPoint.PpSaveAsFileType.ppSaveAsHTML, 
  18.                     Microsoft.Office.Core.MsoTriState.msoCTrue);
  19.             }
  20.             finally
  21.             {
  22.                 if (pptFile != null)
  23.                 {
  24.                     pptFile.Close();
  25.                 }
  26.                 ppt.Quit();
  27.                 GC.Collect();
  28.             }
  29.         }

  30.         /// <summary>
  31.         /// 将Excel文件转换成HTML格式
  32.         /// </summary>
  33.         /// <param name="ExcelFilePath">Excel文件路径</param>
  34.         public static void ExcelToHtmlFile(string ExcelFilePath)
  35.         {
  36.             Microsoft.Office.Interop.Excel.Application excelApp = new Microsoft.Office.Interop.Excel.Application();
  37.             Microsoft.Office.Interop.Excel.Workbook oBook = null;
  38.             // 缺省参数 
  39.             object Unknown = Type.Missing;
  40.             try
  41.             {
  42.                 //目标html文件路径
  43.                 object Target = ExcelFilePath.Substring(0, ExcelFilePath.LastIndexOf(".")) + ".html";
  44.                 //为了保险,只读方式打开 
  45.                 object readOnly = true;
  46.                 // 指定另存为格式(html) 
  47.                 object format = Microsoft.Office.Interop.Excel.XlFileFormat.xlHtml;

  48.                 //打开Excel文件
  49.                 oBook = excelApp.Workbooks.Open(ExcelFilePath, Unknown, readOnly,
  50.                     Unknown, Unknown, Unknown, Unknown, Unknown, Unknown,
  51.                     Unknown, Unknown, Unknown, Unknown, Unknown, Unknown);

  52.                 // 转换格式 
  53.                 oBook.SaveAs(Target, format, Unknown, Unknown, Unknown, Unknown,
  54.                     Microsoft.Office.Interop.Excel.XlSaveAsAccessMode.xlNoChange,
  55.                     Unknown, Unknown, Unknown, Unknown, Unknown);
  56.             }
  57.             finally
  58.             {
  59.                 if (oBook != null)
  60.                 {
  61.                     oBook.Close(false, Unknown, Unknown);
  62.                 }
  63.                 excelApp.Quit();
  64.                 GC.Collect();
  65.             }
  66.         }

  67.         /// <summary>
  68.         /// 将Word文档转换成HTML格式
  69.         /// </summary>
  70.         /// <param name="WordFilePath">Word文档格式</param>
  71.         public static void WordToHtmlFile(string WordFilePath)
  72.         {
  73.             Microsoft.Office.Interop.Word.Application newApp = new Microsoft.Office.Interop.Word.Application();
  74.             Microsoft.Office.Interop.Word.Document doc = null;
  75.             // 缺省参数 
  76.             object Unknown = Type.Missing;
  77.             try
  78.             {
  79.                 // 指定原文件和目标文件 
  80.                 object Source = WordFilePath;
  81.                 object Target = WordFilePath.Substring(0, WordFilePath.LastIndexOf(".")) + ".html";
  82.                 //为了保险,只读方式打开 
  83.                 object readOnly = true;
  84.                 // 指定另存为格式(html) 
  85.                 object format = Microsoft.Office.Interop.Word.WdSaveFormat.wdFormatHTML;

  86.                 // 打开doc文件 
  87.                 doc = newApp.Documents.Open(ref Source, ref Unknown, ref readOnly,
  88.                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown,
  89.                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown);

  90.                 // 转换格式 
  91.                 doc.SaveAs(ref Target, ref format,
  92.                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown,
  93.                     ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown, ref Unknown);
  94.             }
  95.             finally
  96.             {
  97.                 if (doc != null)
  98.                 {
  99.                     // 关闭文档和Word程序 
  100.                     doc.Close(ref Unknown, ref Unknown, ref Unknown);
  101.                 }
  102.                 newApp.Quit(ref Unknown, ref Unknown, ref Unknown);
  103.                 GC.Collect();
  104.             }
  105.         }
复制代码
有了这三个方法,我们可以在 上传 文件时将对应的office文件转成html的文件,跟office文件放在同一个目录中,同时加一个对应的链接“HTML方式查看”即可。

如果是第二期添加这个功能,那可以在获得文件列表的时候,先取得文件的扩展名,然后再查看有没有对应的HTML文件,如果没有,则即时生成一个,很方便,不过如果量很大的话,转换的速度会比较慢,最好是写一个winform的程序遍历整个目录,先把html文件生成一遍,这样再打开就会很快了。 

简单的写一个如下:
  1.         /// <summary>
  2.         /// 生成文件对应的HTML版本(没有考虑HTML文件已经存在的处理)
  3.         /// </summary>
  4.         /// <param name="fileFullName">文件路径</param>
  5.         /// <returns>如果生成了对应的HTML文件,返回true,如果不需要生成HTML文件,返回flase</returns>
  6.         public static bool ConvertFileToHtml(string fileFullName)
  7.         {
  8.             System.IO.FileInfo file = new System.IO.FileInfo(fileFullName);
  9.             if (file.Exists)
  10.             {
  11.                 string strExt = file.Extension.Substring(1).ToLower();

  12.                 switch (strExt)
  13.                 {
  14.                     case "doc":
  15.                     case "docx":
  16.                         WordToHtmlFile(fileFullName);
  17.                         return true;
  18.                     case "xls":
  19.                     case "xlsx":
  20.                         ExcelToHtmlFile(fileFullName);
  21.                         return true;
  22.                     case "ppt":
  23.                     case "pptx":
  24.                         PptToHtmlFile(fileFullName);
  25.                         return true;
  26.                     default:
  27.                         return false;
  28.                 }
  29.             }
  30.             return false;
  31.         }
复制代码
这样就OK了
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值