檢索 COM 類工廠中 CLSID 為 {00024500-0000-0000-C000-000000000046} 的組件時失敗,原因是出現(xiàn)以下錯誤: 80070005。
這樣給Asp.NET操作Microsoft Office對象帶來了一定的困難。但我們還是要想辦法來進(jìn)行Office對象的操作。下面簡單介紹一下本人在開發(fā)過程中曾經(jīng)使用過的方法:
方法1:配置Web.Config文件,在每次請求時模擬本地系統(tǒng)的賬戶。
具體操作:在Web.Config文件中添加如下節(jié)點:
<identity impersonate="true" userName="accountname" password="password" />
其中:userName是要模擬的本地賬號,password是該賬號的密碼。
方法2:在“DCOM配置”中,為IIS賬號配置操作Word(其他Office對象也一樣)的權(quán)限。
具體操作:“組件服務(wù)(Component Service)”->計算機(jī)(Computers)->我的電腦(My Computer)->DCOM配置(DCOM Config)->Microsoft Office Word 97 - 2003 文檔,右擊“Microsoft Office Word 97 - 2003 文檔”,選擇“屬性”進(jìn)行一下兩步操作:
(1)在【標(biāo)識(Identity)】選項卡中選中“交互式用戶(The interactive user)”.
(2)在【安全(Security)】選項卡中,分別給前兩個組(啟動和激活權(quán)限,訪問權(quán)限)選擇“自定義(customer)”,然后點“編輯”,在彈出的界面中添加IIS賬號(Server版的操作系統(tǒng)一般為NETWORK SERVICES,其他系統(tǒng)(XP)可能會是ASP.NET),并在下面的權(quán)限框中,給該用戶分配所有權(quán)限。
方法3:為ASP.NET站點應(yīng)用池分配本地賬號
具體操作:在IIS中,為ASP.NET站點創(chuàng)建新的應(yīng)用程序池,再改應(yīng)用程序池屬性的【標(biāo)識(identity)】選項卡中,為“預(yù)定義賬戶”選擇“本地系統(tǒng)(LocalSystem)”。
如果是IIS7.0中,則按以下步驟操作:為ASP.NET站點創(chuàng)建新的應(yīng)用程序池。選中該應(yīng)用程序池,高級設(shè)置->進(jìn)程模式—>標(biāo)識:選擇localSystem。
以上三種方法中,個人比較喜歡用第三種,因為在操作完Word對象后,還需要關(guān)閉Word對象的進(jìn)程,而第三種方法可以不要其他設(shè)置就能讓ASP.NET應(yīng)用程序有權(quán)限去結(jié)束這個word進(jìn)程。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com