程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> ASP.NET >> ASP.NET基礎 >> ASP.NET操作Word的IIS權限設置

ASP.NET操作Word的IIS權限設置

編輯:ASP.NET基礎
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進程。
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved