檢查權限時,對Server.CreateObject的調用失敗,拒絕對此對象的訪問給出下面的解決方法
今天把一個網站的數據從win2000服務器轉移到了win2003服務器上,然後調試,發現在用aspjpeg組件上傳圖片的時候,提示出錯:
其實很多時候是因爲你安裝的插件權限設置不當造成的。應該堅持你最近安裝了什麼組件。
最終找到了解決“檢查權限時,對Server.CreateObject的調用失敗,拒絕對此對象的訪問”的方法:
windows server 2003默認的安全級別太高了,找到你組件所在的安裝目錄,右鍵/屬性/安全,添加everyone(我用的是IUSR_WD)的可執行權限,再上傳試試看,是不是ok了?
我用到aspjpeg和aspupload兩個組件,所以這2個安裝目錄都給予IUSR_WD可執行權限。
Server 對象 錯誤 'ASP 0178 : 80070005'
Server.CreateObject 訪問錯誤
/upzip/up023ff.asp,行 49
檢查權限時,對 Server.CreateObject 的調用失敗。拒絕對此對象的訪問。
找到第49行,發現是:
Set Photo = Server.CreateObject("Persits.Jpeg") '建立對象
問題原因出來了,Aspjpeg組件調用的權限不夠,這是由於默認的win2003服務器的安全設置太高,導致Aspjpeg組件的上傳權限不夠。必須對win2003服務器做相關的設置,才能解決問題。
解決方法:
1、調用Server.CreateObject("Persits.Jpeg")的時候發生錯誤,解決如下:
開始->運行->dcomcnfg
找到"aspjpeg"(這個名稱取決於你調用的Object是什麼),然後右鍵->屬性->安全 把讀寫權限都給everyone即可。
2、也可以把aspjpeg.dll的讀寫權限賦給相關的用戶。在aspjpeg.dll上右鍵--屬性--安全----添加--高級--立即查找--添加users,默認讀取、讀取和運行權限即可。
3、IIS裏->目錄安全性->編輯->匿名訪問 去勾->確定後 可以訪問了,然後再重新設置一遍,把匿名訪問 加勾,以後就可以正常訪問了。
補充:微軟的知識庫裏面搜索了一下找到一篇,他說設置一下%ProgramFiles%\Common Files\System的權限:Add Everyone to the existing permissions, give at least Read permissions to Everyone, and apply these new settings to all files and subfolders.
這裏要賦予Everyone可以讀和可以修改的權限,光光給可讀的權限是不夠的,必須給可修改(或可寫)的權限,才能解決該錯誤。