線上預覽WORD文件,PDF文件
在網上找了很多資料,發現這方面的資料不多,也不是很完整,以下是我整理的一些東西,希望能給大家有幫助
1.所用工具:FlashPaper,FlashPaper是一個虛擬印表機,可將word檔案轉化成swf格式檔案(.doc .xls .txt .pdf等檔案都可以正常生成SWF格式),既然轉換成SWF了,就知道怎麼顯示了吧,下面我將說到利用FlashPaper轉換成SWF的程式碼
2.步驟:
(1)安裝FlashPape:下載FlashPape壓縮包,解壓縮後,執行初始化目錄中的初始化.bat,然後安裝FlashPaperDriverInstall2.exe,即FlashPaper印表機。特別注意,在有的機器上要更改Macromedia FlashPape的埠,應為FlashPape2PrinterPort,如果是LPT1這個埠,當然打印不出來了。
(2)為頁面中的按鈕編寫事件處理程式碼:
Process process = new Process(); //建立程序物件 //try //{ ProcessStartInfo startInfo = new ProcessStartInfo(); string paperroot = @"C:\Program Files\Macromedia\FlashPaper 2\FlashPrinter.exe";//這裡是FlashPrinter的路徑 string docFile = Server.MapPath("1.doc"); string swfFile = Server.MapPath("1.swf"); startInfo.FileName = paperroot; startInfo.Arguments = docFile + " -o " + swfFile; startInfo.UseShellExecute = false; //不使用系統外殼程式啟動 startInfo.RedirectStandardInput = false; //不重定向輸入 startInfo.RedirectStandardOutput = false; //重定向輸出 startInfo.CreateNoWindow = true; //不建立視窗 process.StartInfo = startInfo; process.Start(); Response.Write("已經提交生成。<br />"); Response.Write(paperroot+"<br />"+docFile + " = " + swfFile); //} //catch (Exception ex) //{ // Response.Write(ex.Message); //} //finally //{ if (process != null) process.Close(); // Response.Write("<br />finally"); //}
許可權問題,簡單的解決方法如下:
在Windows xp系統下請把aspnet賬號(如果是vista,則是networkservice)新增至administrators組,並重啟iis admin服務。
在 windows server 2003下不用說了吧。一樣是 networkservice 並重啟iis admin服務
ASP.NET操作Word的IIS許可權配置
ASP.NET賬號在預設情況下是沒有許可權操作Microsoft Office物件的,如果不進行許可權的配置,程式碼會丟擲類似以下的異常:
檢索 COM 類工廠中 CLSID 為 {00024500-0000-0000-C000-000000000046} 的元件時失敗,原因是出現以下錯誤: 80070005。
這樣給Asp.NET操作Microsoft Office物件帶來了一定的困難。但我們還是要想辦法來進行Office物件的操作。下面簡單介紹一下本人在開發過程中曾經使用過的方法:
方法1:配置Web.Config檔案,在每次請求時模擬本地系統的賬戶。
具體操作:在Web.Config檔案中新增如下節點:
<identity impersonate="true" userName="accountname" password="password" />
其中:userName是要模擬的本地賬號,password是該賬號的密碼。
方法2:在“DCOM配置”中,為IIS賬號配置操作Word(其他Office物件也一樣)的許可權。
具體操作:“元件服務(Component Service)”->計算機(Computers)->我的電腦(My Computer)->DCOM配置(DCOM Config)->Microsoft Office Word 97 - 2003 文件,右擊“Microsoft Office Word 97 - 2003 文件”,選擇“屬性”進行一下兩步操作:
(1)在【標識(Identity)】選項卡中選中“互動式使用者(The interactive user)”.
(2)在【安全(Security)】選項卡中,分別給前兩個組(啟動和啟用許可權,訪問許可權)選擇“自定義(customer)”,然後點“編輯”,在彈出的介面中新增IIS賬號(Server版的作業系統一般為NETWORK SERVICES,其他系統(XP)可能會是ASP.NET),並在下面的許可權框中,給該使用者分配所有許可權。
方法3:為ASP.NET站點應用池分配本地賬號
具體操作:在IIS中,為ASP.NET站點建立新的應用程式池,再改應用程式池屬性的【標識(identity)】選項卡中,為“預定義賬戶”選擇“本地系統(LocalSystem)”。
如果是IIS7.0中,則按以下步驟操作:為ASP.NET站點建立新的應用程式池。選中該應用程式池,高階設定->程序模式—>標識:選擇localSystem。
以上三種方法中,個人比較喜歡用第三種,因為在操作完Word物件後,還需要關閉Word物件的程序,而第三種方法可以不要其他設定就能讓ASP.NET應用程式有許可權去結束這個word程序。