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

2025-05-29 0 55

1.功能说明

输入文件路径,在浏览器输出文件预览信息,经测试360极速(Chrome)、IE9/10、Firefox通过

2.分类文件及代码说明

DemoFiles 存放可测试文件

Default.aspx 启动页

ExcelPreview.cs Excel预览

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27
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预览

?

1

2

3

4

5

6

7

8
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 文本文件预览

?

1

2

3

4

5

6

7

8

9
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预览

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

Microsoft Word 15.0
Microsoft Excel 15.0

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

预览效果

1、Word

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

2、Excel

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

3、Pdf

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

4、Txt

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

未解决的问题

Pdf、txt文件只能在当前页显示,并导致后退键无效,请各位帮忙解决此两种文件和doc、xls一样在新的tab中打开

5.源码下载

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持快网idc!

原文链接:http://www.cnblogs.com/gossip/p/3473024.html

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码) https://www.kuaiidc.com/100509.html

相关文章

发表评论
暂无评论