在ASP中實現通用的絕對路徑產生方法

來源:互聯網
上載者:User
  在我開發ASP + Access的Web應用時,都會遇到資料庫檔案路徑的定位問題。如果在自己的電腦上實現時可以直接指定了事,但如果做的項目要上傳到別的伺服器或移動別的機器上運行使用,每次都要把這個路徑改來改去的話顯得有些繁鎖,下面結合我做這個網站的經驗來解決這個問題,讓我們可以“一勞永逸”。

  在ASP中使用Server.MapPath("file.asp")語句後,會返回該檔案在本地磁碟機上的絕對路徑,如“D:\MySite\test\file.asp”,所以在不同的子目錄的不同檔案使用這條語句就只會返回那個檔案所在路徑,這樣我們就不能簡單地利用這條語句解決上面的問題,但只要稍加利用這條方法和其它與個字元函數就可以輕鬆解決上面的問題。

  現在假設你的網站目錄結構如下:
  MySite
    |- db
      |- db1.mdb
      |- db2.mdb
    |- sub_folder
      |- hello.asp
      |- search.asp
    |- index.asp

只要我們在需要訪問資料庫的asp檔案中加入以下語句:


if session("rootDir") = "" then
dim str
str = Server.MapPath("db")
session("rootDir") = Mid(str, 1, InStr(1, str, "MySite", 1) - 1) & "MySite\db"
end if
...
Set conn = Server.CreateObject("adodb.connection")
conn.Open "driver={Microsoft Access Driver (*.mdb)};dbq=" & session("rootDir") & "\db1.mdb" & ";pwd=" & pw


  這樣在session("rootDir")中就存放你網站中子目錄“db”的絕結路徑,當你改變你網站的主目錄或移到別的機器的情況下就可以不需要理會資料庫檔案的存取路徑問題了。



聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.