1.ASP.NET中:
拋發異常System.Data.OleDb.OleDbException: Unspecified error
錯誤 '0x80004005' 未指定的錯誤
產生此問題的解決方案如下:
(1).MSDN裡的說明,這是因為沒有許可權在臨時目錄裡寫檔案而產生的。這種問題的原因:系統temp檔案夾存取權限不夠 修改方法如下: 進工具-檔案夾選項-查看- 把使用簡單檔案分享權限設定(推薦),關掉。然後進windows/temp,單擊右鍵選擇-屬性,你就會看到一個叫做“安全”的選項,添加一個everyone,使用權限設定為完全控制 ,再將你正在使用windows的使用者也設定為完全控制,就OK了。
(2).用ASP.NET的寫的WEB程式,當訪問量過多後,在登入時就會報錯Unspecified error 0x80004005,是連不上資料庫了,尋找了相關原因,是伺服器上IIS向臨時 檔案夾寫檔案寫滿了,寫不進去了,要重新啟動一下伺服器,或者要清理臨時檔案或者調整磁碟空間(用磁碟配額。給IIS帳號:Internet Guest Account在C盤 足夠大空間的寫入權限) 或者 把臨時檔案夾定義到別的足夠大的磁碟。
(3).回收一下IIS的程式池就好了.
串連語句:
Provider = Microsoft.Jet.OLEDB.4.0 ;Data Source = 'D:\ETSD2\upload\Customer.csv';Extended Properties='Excel 8.0;HDR=YES;IMEX=1'
2.ASP中:
Microsoft JET Database Engine
一是要把網頁檔案目錄設定為Internet使用者可修改可讀。
在“安全”選項卡下,點擊“添加……”,跳出“選擇使用者和組”對話方塊
然後點擊“立即尋找”,在所示的列表中選擇“IUSR_”(底線之後是你的電腦名稱 IUSER_您的機器名)
之後在“安全”選項卡中就會出現“Internet來賓帳戶”,將這個帳戶的使用權限設定為“可修改”和“可寫入”
最後按確定,問題得到解決,不會再出現“Microsoft OLE DB Provider for ODBC Drivers (0x80004005)”錯誤 !
二是要把C:\Windows\temp檔案夾設定為Internet使用者可修改可讀。
系統的臨時目錄下(%windir%/temp/ )建立一個臨時檔案,而這個目錄的許可權不夠。把這個目錄加上IUSER_電腦名的讀寫權限即可
開啟C:\Windows\Temp目錄,並加入使用者IUSR_xxx((開啟IIS,右擊屬性,查看安全目錄裡的使用者是否為IUSR_xxx,如果是就加此使用者,如果為其他使用者名稱即在Temp目 錄加同樣的使用者即可!)有寫的許可權的,就是%SystemRoot%\Temp(即預設安裝系統情況下的C:\Windows\Temp)目錄