在Web頁面上直接打開、編輯、創建word和EXCEL文件
在Web頁面上直接打開、編輯、創建word和EXCEL文件
作者:佚名 日期:2007年08月27日 來源:不詳 瀏覽:58 次
--------------------------------------------------------------------------------
核心提示: 友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點擊.doc文檔鏈接時Word在IE中被打開那樣。想想這個問題應該很多人都會感興趣,所以干脆寫一篇blog來大致描述一下方法。 裝Office2003以后,有一個ActiveX控件被安裝到了系統中,這個控件位于“Program Files\\Microsoft&nbs
-
友詢問如何在Web頁面上做到像SharePoint中的效果一樣,能直接激活客戶端的Word來打開.doc文件,而不是類似直接點擊.doc文檔鏈接時Word在IE中被打開那樣。想想這個問題應該很多人都會感興趣,所以干脆寫一篇blog來大致描述一下方法。
裝Office2003以后,有一個ActiveX控件被安裝到了系統中,這個控件位于“Program Files\\Microsoft Office\\OFFICE11\\owssupp.dll”。通過這個控件,客戶端頁面上的javascript就可以激活本地的Office軟件,來實現打開、編輯Office文檔。(另,Office XP應該就已經包含這個ActiveX控件了。)
,用Script創建一個本地的對象:
enDocObj = 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程序在線編輯文件又如何?
enDocObj.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。
posted on 2010-11-01 16:40 aiaiwoo 閱讀(771) 評論(0) 編輯 收藏 所屬分類: ASP/Visual Basic