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