最近因爲要用.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("")會出現錯誤。)
<%
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方法,也不必受其限制。目前來看,雖然有點笨,但還是最好的方法。