源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码)

  • 时间:2021-07-12 22:56 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码)
[b]1.功能说明[/b] 输入文件路径,在浏览器输出文件预览信息,经测试360极速(Chrome)、IE9/10、Firefox通过 [b]2.分类文件及代码说明 [/b] DemoFiles 存放可测试文件 Default.aspx  启动页 ExcelPreview.cs  Excel预览类
public static void Priview(System.Web.UI.Page p, string inFilePath, string outDirPath = "")
 {
 Microsoft.Office.Interop.Excel.Application excel = null;
 Microsoft.Office.Interop.Excel.Workbook xls = null;
 excel = new Microsoft.Office.Interop.Excel.Application();
 object missing = Type.Missing;
 object trueObject = true;
 excel.Visible = false;
 excel.DisplayAlerts = false;
 string randomName = DateTime.Now.Ticks.ToString(); //output fileName
 xls = excel.Workbooks.Open(inFilePath, missing, trueObject, missing,
     missing, missing, missing, missing, missing, missing, missing, missing,
     missing, missing, missing);
 //Save Excel to Html
 object format = Microsoft.Office.Interop.Excel.XlFileFormat.xlHtml;
 Workbook wsCurrent = xls;//(Workbook)wsEnumerator.Current;
 String outputFile = outDirPath + randomName + ".html";
 wsCurrent.SaveAs(outputFile, format, missing, missing, missing,
    missing, XlSaveAsAccessMode.xlNoChange, missing,
    missing, missing, missing, missing);
 excel.Quit();
 //Open generated Html
 Process process = new Process();
 process.StartInfo.UseShellExecute = true;
 process.StartInfo.FileName = outputFile;
 process.Start();
 } 
[b]4.PDfPreview.cs   Pdf预览类[/b]
public static void Priview(System.Web.UI.Page p, string inFilePath)
 {
 p.Response.ContentType = "Application/pdf";
 string fileName = inFilePath.Substring(inFilePath.LastIndexOf('\\') + 1);
 p.Response.AddHeader("content-disposition", "filename=" + fileName);
 p.Response.WriteFile(inFilePath);
 p.Response.End();
 }
[b]5.TextFilePreview.cs  文本文件预览类[/b]
 public static void Preview(System.Web.UI.Page p, string inFilePath)
 {
 string fileName = inFilePath.Substring(inFilePath.LastIndexOf('\\') + 1);
 p.Response.ContentType = "text/plain";
 p.Response.ContentEncoding = System.Text.Encoding.UTF8; //保持和文件的编码格式一致
 p.Response.AddHeader("content-disposition", "filename=" + fileName);
 p.Response.WriteFile(inFilePath);
 p.Response.End();
 }
[b]6. WordPreview.cs  Word预览类[/b] [b]7.Readme.txt  说明了基本功能及引用Com组件的方法(首先需要安装office),需引入的组件包括[/b]   Microsoft Word 15.0   Microsoft Excel 15.0 [img]http://files.jb51.net/file_images/article/201612/2016120911574711.png[/img] [b]  预览效果 [/b] 1、Word [img]http://files.jb51.net/file_images/article/201612/2016120911574712.png[/img] 2、Excel  [img]http://files.jb51.net/file_images/article/201612/2016120911574713.png[/img] 3、Pdf [img]http://files.jb51.net/file_images/article/201612/2016120911574814.png[/img] 4、Txt [img]http://files.jb51.net/file_images/article/201612/2016120911574815.png[/img] [b]未解决的问题[/b] Pdf、txt文件只能在当前页显示,并导致后退键无效,请各位帮忙解决此两种文件和doc、xls一样在新的tab中打开 [b]5.[url=http://xiazai.jb51.net/201612/yuanma/FilePreviewInBrowser_jb51.rar]源码下载[/url]:[url=http://xiazai.jb51.net/201612/yuanma/FilePreviewInBrowser_jb51.rar]http://xiazai.jb51.net/201612/yuanma/FilePreviewInBrowser_jb51.rar[/url][/b] 以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持编程素材网!
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部