溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

發(fā)布時間:2021-08-26 15:30:56 來源:億速云 閱讀:355 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

1.功能說明

輸入文件路徑,在瀏覽器輸出文件預(yù)覽信息,經(jīng)測試360極速(Chrome)、IE9/10、Firefox通過

2.分類文件及代碼說明

DemoFiles 存放可測試文件

Default.aspx  啟動頁

ExcelPreview.cs  Excel預(yù)覽類

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();
 }

4.PDfPreview.cs   Pdf預(yù)覽類

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();
 }

5.TextFilePreview.cs  文本文件預(yù)覽類

 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();
 }

6. WordPreview.cs  Word預(yù)覽類

7.Readme.txt  說明了基本功能及引用Com組件的方法(首先需要安裝office),需引入的組件包括

  Microsoft Word 15.0
  Microsoft Excel 15.0

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

  預(yù)覽效果

1、Word

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

2、Excel 

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

3、Pdf

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

4、Txt

Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件

未解決的問題

Pdf、txt文件只能在當(dāng)前頁顯示,并導(dǎo)致后退鍵無效,請各位幫忙解決此兩種文件和doc、xls一樣在新的tab中打開

以上是“Asp.net如何實現(xiàn)直接在瀏覽器預(yù)覽Word、Excel、PDF、Txt文件”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI