天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

.NET實現在網頁中預覽Office文件的3個方法

近日公司要搞一個日常的文檔管理的東東,可以上傳、下載各種文件,如果是office文件呢還必須得支持預覽功能,其他的都好說但是唯獨office預覽功能比較麻煩,但是不能不做,廢話不多說了一步步來吧。分析了下網易郵箱的文件預覽功能,他用的是微軟的組件,最早叫Office online,現在分開了叫Word online、Excel online ....等等,效果十分炫酷功能十分強大,但是查看了下對api的說明發現對服務器的要求比較苛刻而且配置比較復雜不太適合。然后 又看了下騰訊用的是永中第三方組件,效果嘛自然比不上微軟的但是能用,綜合網上的一些資料大概也就那么幾種方式實現

1.使用Microsoft的Office組件將文件直接轉換為html文件(優點:代碼實現最簡單,工作強度最小。缺點:效果極差)

2.使用Microsoft的Office組件將文件轉換為PDF格式文件,然后再使用pdf2swf轉換為swf文件,也就是flash文件在使用FlexPaper展示出來(優點:預覽效果能接受,缺點:代碼量大)

效果如圖:

3. 使用Office online(優點:表現完美,缺點:不適合中小企業應用)

綜合考慮決定使用第二種方法,經過次次波折終于可以使用,但是有個問題至今沒有得到解決,調用Office組件的時候有時候會出現如下異常:

檢索 COM 類工廠中 CLSID 為 {000209FF-0000-0000-C000-000000000046} 的組件失敗,原因是出現以下錯誤: 8000401a 因為配置標識不正確,系統無法開始服務器進程。請檢查用戶名和密碼。 (異常來自 HRESULT:0x8000401A),查閱無數資料還是不能解決,最讓人不可接受的的是office文件必須標標準準毫無容錯能力,當轉換ppt文件時竟然會彈出轉換進度框!!

好吧!那么我們改進它。

使用ASPOSE+pdf2swf+FlexPaper

關于ASPOSE大家可以到官網了解,這是款商業收費產品但是免費也可以使用

1、引用dll

2、編寫轉換幫助類

復制代碼 代碼如下:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using ASPose.Cells;
using ASPose.Words;
using ASPose.Slides;
using System.Text.RegularExpressions;
using System.IO;

namespace Souxuexiao.Common
{
    /// <summary>
    /// 第三方組件ASPOSE Office/WPS文件轉換
    /// Writer:Helen Joe
    /// Date:2014-09-24
    /// </summary>
    public class ASPoseUtils
    {
        /// <summary>
        /// PFD轉換器位置
        /// </summary>
        private static string _EXEFILENAME = System.Web.HttpContext.Current != null
                ? System.Web.HttpContext.Current.Server.MapPath("/pdf2swf/pdf2swf.exe")
                : System.IO.Path.Combine(AppDomain.CurrentDomain.BaseDirectory + "http://pdf2swf//pdf2swf.exe");

        #region 1.01 Wrod文檔轉換為PDF文件 +ConvertDocToPdF(string sourceFileName, string targetFileName)
        /// <summary>
        /// Wrod文檔轉換為PDF文件
        /// </summary>
        /// <param name="sourceFileName">需要轉換的Word全路徑</param>
        /// <param name="targetFileName">目標文件全路徑</param>
        /// <returns>轉換是否成功</returns>
        public static bool ConvertDocToPdF(string sourceFileName, string targetFileName)
        {
            Souxuexiao.API.Logger.error(string.Format("Wrod文檔轉換為PDF文件:sourceFileName={0},targetFileName={1}", sourceFileName, targetFileName));
            try
            {
                using (System.IO.Stream stream = new System.IO.FileStream(sourceFileName, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.ReadWrite))
                {
                    Document doc = new Document(sourceFileName);
                    doc.Save(targetFileName, ASPose.Words.SaveFormat.Pdf);
                }
            }
            catch (Exception ex)
            {
                Souxuexiao.API.Logger.error(string.Format("Wrod文檔轉換為PDF文件執行ConvertDocToPdF發生異常原因是:{0}",ex.Message));
            }
            return System.IO.File.Exists(targetFileName);
        }
        #endregion

        #region 1.02 Excel文件轉換為HTML文件 +(string sourceFileName, string targetFileName, string guid)
        /// <summary>
        /// Excel文件轉換為HTML文件
        /// </summary>
        /// <param name="sourceFileName">Excel文件路徑</param>
        /// <param name="targetFileName">目標路徑</param>
        /// <returns>轉換是否成功</returns>
        public static bool ConvertExcelToHtml(string sourceFileName, string targetFileName)
        {
            Souxuexiao.API.Logger.info(string.Format("準備執行Excel文件轉換為HTML文件,sourceFileName={0},targetFileName={1}",sourceFileName,targetFileName));
            try
            {
                using (System.IO.Stream stream = new System.IO.FileStream(sourceFileName, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.ReadWrite))
                {
                    ASPose.Cells.Workbook workbook = new Workbook(stream);
                    workbook.Save(targetFileName, ASPose.Cells.SaveFormat.Html);
                }
            }
            catch (Exception ex)
            {
                Souxuexiao.API.Logger.error(string.Format("Excel文件轉換為HTML文件ConvertExcelToHtml異常原因是:{0}", ex.Message));
            }
            return System.IO.File.Exists(targetFileName);
        }
        #endregion

        #region 1.03 將PowerPoint文件轉換為PDF +ConvertPowerPointToPdf(string sourceFileName, string targetFileName)
        /// <summary>
        /// 將PowerPoint文件轉換為PDF
        /// </summary>
        /// <param name="sourceFileName">PPT/PPTX文件路徑</param>
        /// <param name="targetFileName">目標文件路徑</param>
        /// <returns>轉換是否成功</returns>
        public static bool ConvertPowerPointToPdf(string sourceFileName, string targetFileName)
        {
            Souxuexiao.API.Logger.info(string.Format("準備執行PowerPoint轉換PDF,sourceFileName={0},targetFileName={1}",sourceFileName,targetFileName));
            try
            {
                using (System.IO.Stream stream = new System.IO.FileStream(sourceFileName, System.IO.FileMode.Open, System.IO.FileAccess.Read, System.IO.FileShare.ReadWrite))
                {
                    ASPose.Slides.Pptx.PresentationEx pptx = new ASPose.Slides.Pptx.PresentationEx(stream);
                    pptx.Save(targetFileName, ASPose.Slides.Export.SaveFormat.Pdf);
                }
            }
            catch (Exception ex)
            {
                Souxuexiao.API.Logger.error(string.Format("將PowerPoint文件轉換為PDFConvertExcelToHtml異常原因是:{0}", ex.Message));
            }
            return System.IO.File.Exists(targetFileName);
        }
        #endregion

        #region 2.01 讀取pdf文件的總頁數 +GetPageCount(string pdf_filename)
        /// <summary>
        /// 讀取pdf文件的總頁數
        /// </summary>
        /// <param name="pdf_filename">pdf文件</param>
        /// <returns></returns>
        public static int GetPageCountByPDF(string pdf_filename)
        {
            int pageCount = 0;
            if (System.IO.File.Exists(pdf_filename))
            {
                try
                {
                    byte[] buffer = System.IO.File.ReadAllBytes(pdf_filename);
                    if (buffer != null && buffer.Length > 0)
                    {
                        pageCount = -1;
                        string pdfText = Encoding.Default.GetString(buffer);
                        Regex regex = new Regex(@"/Type/s*/Page[^s]");
                        MatchCollection conllection = regex.Matches(pdfText);
                        pageCount = conllection.Count;
                    }
                }
                catch (Exception ex)
                {
                    Souxuexiao.API.Logger.error(string.Format("讀取pdf文件的總頁數執行GetPageCountByPowerPoint函數發生異常原因是:{0}", ex.Message));
                }
            }
            return pageCount;
        }
        #endregion

        #region 2.02 轉換PDF文件為SWF格式 +PDFConvertToSwf(string pdfPath, string swfPath, int page)
        /// <summary>
        /// 轉換PDF文件為SWF格式
        /// </summary>
        /// <param name="pdfPath">PDF文件路徑</param>
        /// <param name="swfPath">SWF生成目標文件路徑</param>
        /// <param name="page">PDF頁數</param>
        /// <returns>生成是否成功</returns>
        public static bool PDFConvertToSwf(string pdfPath, string swfPath, int page)
        {
            StringBuilder sb = new StringBuilder();
            sb.Append(" /"" + pdfPath + "/"");
            sb.Append(" -o /"" + swfPath + "/"");
            sb.Append(" -z");
            //flash version
            sb.Append(" -s flashversion=9");
            //禁止PDF里面的鏈接
            sb.Append(" -s disablelinks");
            //PDF頁數
            sb.Append(" -p " + "/"1" + "-" + page + "/"");
            //SWF中的圖片質量
            sb.Append(" -j 100");
            string command = sb.ToString();
            System.Diagnostics.Process p = null;
            try
            {
                using (p = new System.Diagnostics.Process())
                {
                    p.StartInfo.FileName = _EXEFILENAME;
                    p.StartInfo.Arguments = command;
                    p.StartInfo.WorkingDirectory = System.IO.Path.GetDirectoryName(_EXEFILENAME);
                    //不使用操作系統外殼程序 啟動 線程
                    p.StartInfo.UseShellExecute = false;
                    //p.StartInfo.RedirectStandardInput = true;
                    //p.StartInfo.RedirectStandardOutput = true;

                    //把外部程序錯誤輸出寫到StandardError流中(pdf2swf.exe的所有輸出信息,都為錯誤輸出流,用 StandardOutput是捕獲不到任何消息的...
                    p.StartInfo.RedirectStandardError = true;
                    //不創建進程窗口
                    p.StartInfo.CreateNoWindow = false;
                    //啟動進程
                    p.Start();
                    //開始異步讀取
                    p.BeginErrorReadLine();
                    //等待完成
                    p.WaitForExit();
                }
            }
            catch (Exception ex)
            {
                Souxuexiao.API.Logger.error(string.Format("轉換PDF文件為SWF格式執行PDFConvertToSwf函數發生異常原因是:{0}", ex.Message));
            }
            finally
            {
                if (p != null)
                {
                    //關閉進程
                    p.Close();
                    //釋放資源
                    p.Dispose();
                }
            }
            return File.Exists(swfPath);
        }
        #endregion
    }
}
Office格式轉換

3、將pdf文件轉swf的轉換器放到站點根目錄下新建文件夾pdf2swf(我就是這么配置的,您隨意)

4、配置FlexPaper

預覽頁面引用

 復制代碼 代碼如下:
 <script src="/FlexPaper/js/swfobject.js" type="text/Javascript"></script>
<script type="text/Javascript" src="/FlexPaper/js/flexpaper_flash.js"></script>
 

控件容器以及設置項

復制代碼 代碼如下:
<div style="margin:0 auto;width:980px;">
            <div id="flashContent" style="display:none;">
                <p>
                    To view this page ensure that Adobe Flash Player version
                    10.0.0 or greater is installed.
                </p>
                <script type="text/Javascript">
                    var pageHost = ((document.location.protocol == "https:") ? "https://" : "http://");
                    document.write("<a ><img src='" + pageHost + "www.adobe.com/images/shared/download_buttons/get_flash_player.gif' alt='Get Adobe Flash player' /></a>");
                </script>
            </div>
        <script type="text/Javascript">
            var _filename = document.getElementById("_filename").value;
            var swfVersionStr = "9.0.0";
            var xiSwfUrlStr = "playerProductInstall.swf";
            var flashvars = {
                SwfFile: escape(_filename),
                Scale: 0.6,
                ZoomTransition: "easeOut",
                ZoomTime: 0.5,
                ZoomInterval: 0.1,
                FitPageOnLoad: false,
                FitWidthOnLoad: true,
                PrintEnabled: true,
                FullScreenAsMaxWindow: false,
                ProgressiveLoading: true,

                PrintToolsVisible: true,
                ViewModeToolsVisible: true,
                ZoomToolsVisible: true,
                FullScreenVisible: true,
                NavToolsVisible: true,
                CursorToolsVisible: true,
                SearchToolsVisible: true,
                SearchMatchAll:true,

                localeChain: "zh_CN"
            };
            var params = {
                quality: "high",
                bgcolor: "#ffffff",
                allowscriptaccess: "sameDomain",
                allowfullscreen: "true"
            }
            var attributes = { id: "FlexPaperViewer", name: "FlexPaperViewer" };
            swfobject.embedSWF("/FlexPaper/FlexPaperViewer.swf", "flashContent", "980", "620", swfVersionStr, xiSwfUrlStr, flashvars, params, attributes);
            swfobject.createCSS("#flashContent", "display:block;text-align:left;");
        </script>
        </div>

document.getElementById("_filename").value是預覽文件的路徑
 
OK  大功告成  ,至于如何上傳,怎么保存上傳的文件等等那些邏輯我這里就省略了。。。。,但是有個建議,當用戶上傳文件之后調用轉換api生成預覽文件是個耗時的操作,

文件越大耗時越長,也就是說生成預覽文件的時候是需要時間的,因此我使用異步方式生成預覽文件。

AspNet技術.NET實現在網頁中預覽Office文件的3個方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 欧美人成在线观看ccc36 | 涩涩涩涩爱网站 | 亚洲精品中文字幕一二三四区 | 国产亚洲欧美在线观看三区 | 第一怡春院| 久久精品视频免费 | 超污视频带污疼免费视频 | 最近中文字幕在线看免费完整版 | 我要色色网 | 国产一区二区三区乱码在线观看 | 破苞流血哭泣 magnet | 八妻子秋霞理在线播放 | 成人免费视频网站www | 嫩草影院精品视频在线观看 | 精品无码三级在线观看视频 | 亚洲免费综合色视频 | 久久一er精这里有精品 | 亚洲无吗精品AV九九久久 | 色午夜日本高清视频www | 色中色成人论坛 | 战狼4在线观看完免费完整版 | 羞羞一区二区三区四区片 | 精品亚洲国产成AV人片传媒 | 国产国产乱老熟女视频网站97 | gayxxxxgay呻吟受日本 | 欧美做真爱欧免费看 | 三级网址在线播放 | 亚洲精品久久久久久偷窥 | 欧美丰满熟妇无码XOXOXO | 2021国产精品视频一区 | 91九色视频无限观看免费 | 高冷师尊被CAO成SAO货 | 亚洲成人mv | 国产高清美女一级a毛片久久w | 在线播放国产视频 | 短篇合集纯肉高H深陷骚 | 国产精品白浆精子流水合集 | 动漫美女被羞羞动漫怪物 | 精品视频一区二区三三区四区 | 精品视频网站 | 被cao的奶水直喷高H |