ASP.NET操作Word的IIS權限設置
添加時間:2014-8-26 21:35:43
添加:
思海網絡
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。
檢索 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進程。
關鍵字:ASP.NET、應用程序、IS、權限
新文章:
- CentOS7下圖形配置網絡的方法
- CentOS 7如何添加刪除用戶
- 如何解決centos7雙系統后丟失windows啟動項
- CentOS單網卡如何批量添加不同IP段
- CentOS下iconv命令的介紹
- Centos7 SSH密鑰登陸及密碼密鑰雙重驗證詳解
- CentOS 7.1添加刪除用戶的方法
- CentOS查找/掃描局域網打印機IP講解
- CentOS7使用hostapd實現無AP模式的詳解
- su命令不能切換root的解決方法
- 解決VMware下CentOS7網絡重啟出錯
- 解決Centos7雙系統后丟失windows啟動項
- CentOS下如何避免文件覆蓋
- CentOS7和CentOS6系統有什么不同呢
- Centos 6.6默認iptable規則詳解