Asp.Net中的MapPath目錄問題

最近因爲要用.Net連接Access數據庫,在數據庫路徑上遇到了麻煩。
找了半天,沒搞懂.Net中的目錄問題。

在古老的asp中,Server.MapPath無比好用,使用Server.MapPath可以很方便的返回物理路徑的上一層;而在.Net中,返回的是虛擬路徑的上一層,鬱悶。

比如我們localhost的物理目錄是“c:\inetpub\wwwroot\”,我們把“D:\mywebsite\test”設置爲web共享, 在“D:\mywebsite\test”下的文件夾“NewFolder1”中,有文件“webform1.aspx”。

運行以下代碼:
 Response.Write(Server.MapPath("") + "<br>");
 Response.Write(Server.MapPath("..") + "<br>");
 Response.Write(Server.MapPath("../") + "<br>");
 Response.Write(Server.MapPath("../../") + "<br>");

輸出:
 D:\mywebsite\test\NewFolder1
 D:\mywebsite\test
 D:\mywebsite\test\
 c:\inetpub\wwwroot\
而在一個Asp文件“test.asp”中,有以下代碼:
 <%
 response.write Server.MapPath("..") + "<br>"
 response.write Server.MapPath("../") + "<br>"
 response.write Server.MapPath("../../") + "<br>"
 %>
(需要說明的是,asp代碼中response.write Server.MapPath("")會出現錯誤。)

輸出:
 D:\mywebsite\test
 D:\mywebsite\test
 D:\mywebsite

正解。

所以,Asp.Net讓人鬱悶。
並且,不論Asp.Net還是Asp,用MapPath方法獲得的物理路徑,都與當前文件所處的目錄有關,所以,在網站中處於不同目錄深度的文件不能調用統一的方法獲得access數據庫的物理路徑,實在是很鬱悶的問題。

解決的辦法,只好是將Access數據庫的物理路徑直接在配置文件中寫好,這樣可以不必使用MapPath方法,也不必受其限制。目前來看,雖然有點笨,但還是最好的方法。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章