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進程。