如何在Web頁面上直接打開、編輯、建立Office文檔
作者:tank 日期:2006-06-15
如何在Web頁面上直接打開、編輯、建立Office文檔
有朋友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點擊.doc文檔鏈接時Word在IE中被打開那樣。想想這個問題應該很多人都會感興趣,所以乾脆寫一篇blog來大致描述一下方法。
在安裝Office2003以後,有一個ActiveX控件被安裝到了系統中,這個控件位於「Program Files\Microsoft Office\OFFICE11\owssupp.dll」。通過這個控件,客戶端頁面上的JavaScript就可以激活本地的Office軟體,來實現打開、編輯Office文檔。(另,Office XP應該就已經包含這個ActiveX控件了。)
首先,用Script建立一個本地的對象:
openDocObj = new ActiveXObject("SharePoint.OpenDocuments.2"); // 為了兼容Office XP,可以建立「SharePoint.OpenDocuments.1」
然後,調用openDocObj的相應的方法。比如打開伺服器上的一個Office文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc");
openDocObj對像會根據參數中不同的Office文檔類型(.doc、.xls、.ppt)來打開不同的程式(Word、Excel、PowerPoint)。ViewDocument()方法還有一個重載簽名,可以讓我們手工指定激活哪個程式來打開文檔:
openDocObj.ViewDocument("http://www.abc.com/documents/sample.doc", 要激活的程式的ProgID);
那麼要打開Office程式在線編輯文件又如何?
openDocObj.EditDocument("http://www.abc.com/documents/sample.doc");
就可以直接激活Word,在Word裡面編輯文檔,然後直接點擊Word裡面的保存功能,就可以將文件保存會伺服器上了。注意:為了讓Word能將編輯後的文檔直接保存會伺服器,訪問Web站點的當前上下文的Windows Identity必須對伺服器的相應目錄(即「http://www.abc.com/documents」這個虛擬目錄所對應的伺服器上的物理路徑)有相應的寫權限,否則保存動作會失敗。編輯完成後,EditDocument()會返回一個bool值,來反映編輯操作是否成功。
我們還可以通過打開伺服器上的一個文檔模版,來建立一個新的文檔:
openDocObj.CreateNewDocument("http://www.abc.com/documents/sampleTemplate.dot", "http://www.abc.com/documents/");
就可以使用「http://www.abc.com/documents/sampleTemplate.dot」這個模版來建立一個新的文檔,默認新文檔的保存地點是「http://www.abc.com/documents/」。建立新文檔時使用的程式取決於模版文件的類型(比如.dot模版會對應Word)。新文檔的保存同樣需要注意權限問題。CreateNewDocument()方法同樣會返回一個bool值來反映操作是否成功。
CreateNewDocument()方法的第一個參數,除了可以使用一個模版的地址外,還可以直接指定為希望用來建立新文檔的客戶端程式的ProgID。