html在线预览wordexcel文档,直接在线预览Word、Excel、TXT文件之ASP.NET

具体实现过程不多说了,直接贴代码了。

using System;

using System.Collections.Generic;

using System.Linq;

using System.Web;

using System.Web.Mvc;

using Microsoft.Office.Interop.Excel;

using System.Diagnostics;

using System.IO;

using Microsoft.Office.Interop.Word;

namespace Suya.Web.Apps.Areas.PMP.Controllers

{

///

/// 在线预览Office文件

///

public class OfficeViewController : Controller

{

#region Index页面

///

/// Index页面

///

/// 例:/uploads/......XXX.xls

public ActionResult Index(string url)

{

string physicalPath = Server.MapPath(Server.UrlDecode(url));

string extension = Path.GetExtension(physicalPath);

string htmlUrl = "";

switch (extension.ToLower())

{

case ".xls":

case ".xlsx":

htmlUrl = PreviewExcel(physicalPath, url);

break;

case ".doc":

case ".docx":

htmlUrl = PreviewWord(physicalPath, url);

break;

case ".txt":

htmlUrl = PreviewTxt(physicalPath, url);

break;

case ".pdf":

htmlUrl = PreviewPdf(physicalPath, url);

break;

}

return Redirect(Url.Content(htmlUrl));

}

#endregion

#region 预览Excel

///

/// 预览Excel

///

public string PreviewExcel(string physicalPath, string url)

{

Microsoft.Office.Interop.Excel.Application application = null;

Microsoft.Office.Interop.Excel.Workbook workbook = null;

application = new Microsoft.Office.Interop.Excel.Application();

object missing = Type.Missing;

object trueObject = true;

application.Visible = false;

application.DisplayAlerts = false;

workbook = application.Workbooks.Open(physicalPath, 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;

string htmlName = Path.GetFileNameWithoutExtension(physicalPath) + ".html";

String outputFile = Path.GetDirectoryName(physicalPath) + "\\" + htmlName;

workbook.SaveAs(outputFile, format, missing, missing, missing,

missing, XlSaveAsAccessMode.xlNoChange, missing,

missing, missing, missing, missing);

workbook.Close();

application.Quit();

return Path.GetDirectoryName(Server.UrlDecode(url)) + "\\" + htmlName;

}

#endregion

#region 预览Word

///

/// 预览Word

///

public string PreviewWord(string physicalPath, string url)

{

Microsoft.Office.Interop.Word._Application application = null;

Microsoft.Office.Interop.Word._Document doc = null;

application = new Microsoft.Office.Interop.Word.Application();

object missing = Type.Missing;

object trueObject = true;

application.Visible = false;

application.DisplayAlerts = WdAlertLevel.wdAlertsNone;

doc = application.Documents.Open(physicalPath, missing, trueObject, missing, missing, missing,

missing, missing, missing, missing, missing, missing, missing, missing, missing, missing);

//Save Excel to Html

object format = Microsoft.Office.Interop.Word.WdSaveFormat.wdFormatHTML;

string htmlName = Path.GetFileNameWithoutExtension(physicalPath) + ".html";

String outputFile = Path.GetDirectoryName(physicalPath) + "\\" + htmlName;

doc.SaveAs(outputFile, format, missing, missing, missing,

missing, XlSaveAsAccessMode.xlNoChange, missing,

missing, missing, missing, missing);

doc.Close();

application.Quit();

return Path.GetDirectoryName(Server.UrlDecode(url)) + "\\" + htmlName;

}

#endregion

#region 预览Txt

///

/// 预览Txt

///

public string PreviewTxt(string physicalPath, string url)

{

return Server.UrlDecode(url);

}

#endregion

#region 预览Pdf

///

/// 预览Pdf

///

public string PreviewPdf(string physicalPath, string url)

{

return Server.UrlDecode(url);

}

#endregion

}

}

以上就是针对直接在线预览word、excel、text、pdf文件的全部内容,希望大家喜欢。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值