關(guān)于數(shù)據(jù)庫防下載處理的解決辦法!
當(dāng)前位置:點晴教程→知識管理交流
→『 技術(shù)文檔交流 』
下面提供的的方法分別適用使用虛擬主機空間的用戶和有iis控制權(quán)的用戶! [br]一:購買虛擬主機空間的,適合沒有iis控制權(quán)[br][br]1:發(fā)揮你的想象力 修改數(shù)據(jù)庫文件名[br]這個是最基本的。我想現(xiàn)在也沒有多少連數(shù)據(jù)庫文件名都懶得改的人吧? 至于改成什么,你自己看著辦,至少要保證文件名復(fù)雜,不可猜測性。當(dāng)然這個時候你的數(shù)據(jù)庫所在目錄是不能開放目錄瀏覽權(quán)限的![br][br]2:數(shù)據(jù)庫名后綴改為asa、asp等[br]這個聽說很流行,不過我測試了好多次,發(fā)現(xiàn)并不理想,如果真正要起到防止下載的作用,要進(jìn)行一些2進(jìn)制字段添加等設(shè)置,---一句話,繁而復(fù)雜(如果你的數(shù)據(jù)庫有很多的話,這個方法實在不是很好)[br][br]3:數(shù)據(jù)庫名前加“#”[br]只需要把數(shù)據(jù)庫文件前名加上#、然后修改數(shù)據(jù)庫連接文件(如conn.asp)中的數(shù)據(jù)庫地址。原理是下載的時候只能識別 #號前名的部分,對于后面的自動去掉,比如你要下載:[url=http://pcdigest.com/date/#123.mdb]http://pcdigest.com/date/#123.mdb[/url](假設(shè)存在的話)。無論是ie還是flashget等下到的都是[url=http://pcdigest.com/date/index.htm]http://pcdigest.com/date/index.htm[/url](index.asp、default.jsp等你在iis設(shè)置的首頁文檔)[br]另外在數(shù)據(jù)庫文件名中保留一些空格也起到類似作用,由于http協(xié)議對地址解析的特殊性,空格會被編碼為"%",如[url=http://pcdigest.com/date/123]http://pcdigest.com/date/123[/url] 456.mdb,下載的時[url=http://pcdigest.com/date/123e6.mdb]http://pcdigest.com/date/123%456.mdb[/url]。而我們的目錄就根本沒有123%456.mdb這個文件,所以下載也是無效的這樣的修改后,即使你暴露了數(shù)據(jù)庫地址,一般情況下別人也是無法下載![br][br]4:加密數(shù)據(jù)庫[br]用access將你的數(shù)據(jù)庫以獨占方式打開后,在工具-安全-設(shè)置數(shù)據(jù)庫密碼,加密后要修改數(shù)據(jù)庫連接頁, 如:[br]conn.open "driver={microsoft access driver (*.mdb)};uid=admin;pwd=數(shù)據(jù)庫密碼;dbq=數(shù)據(jù)庫路徑"[br]這樣修改后,數(shù)據(jù)庫即使被人下載了,別人也無法打開(前提是你的數(shù)據(jù)庫連接頁中的密碼沒有被泄露)[br]但值得注意的是,由于access數(shù)據(jù)庫的加密機制比較簡單,即使設(shè)置了密碼,解密也很容易。該數(shù)據(jù)庫系統(tǒng)通過將用戶輸入的密碼與某一固定密鑰進(jìn)行“異或”來形成一個加密串,并將其存儲在*.mdb文件從地址“&h42”開始的區(qū)域內(nèi)。所以一個好的程序員可以輕松制作一個幾十行的小程序就可以輕松地獲得任何access數(shù)據(jù)庫的密碼。因此,只要數(shù)據(jù)庫被下載,其信息安全依然是個未知數(shù)。 [br][br][br][br]二:有主機控制權(quán) (當(dāng)然虛擬空間的設(shè)置在這里依然可以用)[br]5:數(shù)據(jù)庫放在web目錄外[br]如你的web目錄是e:\webroot,可以把數(shù)據(jù)庫放到e:\data這個文件夾里,在e:\webroot里的數(shù)據(jù)庫連接頁中[br]修改數(shù)據(jù)庫連接地址為:"../data/數(shù)據(jù)庫名" 的形式,這樣數(shù)據(jù)庫可以正常調(diào)用,但是無法下載的,因為它不在web目錄里!這個方法一般也不適合購買虛擬空間的用戶。[br][br]6:使用odbc數(shù)據(jù)源。[br]在asp等程序設(shè)計中,如果有條件,應(yīng)盡量使用odbc數(shù)據(jù)源,不要把數(shù)據(jù)庫名寫在程序中,否則,數(shù)據(jù)庫名將隨asp源代碼的失密而一同失密,例如: dbpath = server.mappath(“../123/abc/asfadf.mdb ”) [br]conn.open “driver={microsoft access driver (*.mdb)};dbq=”& dbpath [br]可見,即使數(shù)據(jù)庫名字起得再怪異,隱藏的目錄再深,asp源代碼失密后,也很容易被下載下來。如果使用odbc數(shù)據(jù)源,就不會存在這樣的問題了: conn.open “odbc-dsn名” ,不過這樣是比較煩的,目錄移動的話又要重新設(shè)置數(shù)據(jù)源了,更方便的方法請看第7,8法![br][br]7:添加數(shù)據(jù)庫名的如mdb的擴展映射[br]這個方法就是通過修改iis設(shè)置來實現(xiàn),適合有iis控制權(quán)的朋友,不適合購買虛擬主機用戶(除非管理員已經(jīng)設(shè)置了)。這個方法我認(rèn)為是目前最好的。只要修改一處,整個站點的數(shù)據(jù)庫都可以防止被下載。無須修改代碼即使暴露目標(biāo)地址也可以防止下載,如圖1、2設(shè)置:[br][br][br]我們在 iis屬性---主目錄---配置---映射---應(yīng)用程序擴展那里添加.mdb文件的應(yīng)用解析。注意這里的選擇的dll(或exe等)似乎也不是任意的,選擇不當(dāng),這個mdb文件還是可以被下載的, 注意最好不要選擇選擇asp.dll等。你可以自己多測試下[br]這樣修改后下載數(shù)據(jù)庫如:[url=http://192.168.1.5/haobbs/data/dvbbs6.mdb]http://192.168.1.5/haobbs/data/dvbbs6.mdb[/url]。就出現(xiàn)(404或500等錯誤)[br][br]8:使用.net的優(yōu)越性[br]動網(wǎng)的木鳥就寫過一個防非法下載文件的“wbal 防盜鏈工具”。具體可以登陸[url=http://9seek.com/wbal/]http://9seek.com/wbal/[/url] [br]不過 那個只實現(xiàn)了防止非本地下載的 ,沒有起到真正的防下載數(shù)據(jù)庫的功能。不過這個方法已經(jīng)跟5法差不多[br]可以通過修改.net文件,實現(xiàn)本地也不能下載![br][br]這幾個方法中,只有第7和8個是統(tǒng)一性改的,一次修改配置后,整個站點的數(shù)據(jù)庫都可以防止下載,其他幾個就要分別修改數(shù)據(jù)庫名和連接文件,比較麻煩,不過對于虛擬主機的朋友也只能這樣了![br][br]其實第6個方法應(yīng)該是第5個方法的擴展,可以實現(xiàn)特殊的功能,但對于不支持.net的主機或者怕設(shè)置麻煩的話,還是直接用第5個方法了,而且默認(rèn)情況下第6個方法,依然可以通過復(fù)制連接到同主機的論壇或留言本發(fā)表,然后就可以點擊下載了(因為這樣的引用頁是來自同主機的)[br][br]這幾個方法各有長短,請自己選擇性地使用。這些方法也不是絕對的安全,還需要網(wǎng)站管理員平時注意一些系統(tǒng)的安全,以及寫asp/asp.net/jsp代碼本身的安全 ,否則依然是有可能被人下載或者修改數(shù)據(jù)庫的!
該文章在 2010/7/3 13:23:22 編輯過 |
關(guān)鍵字查詢
相關(guān)文章
正在查詢... |