解讀八種方法防止數(shù)據(jù)庫(kù)被下載_Access數(shù)據(jù)庫(kù)教程
推薦:如何刪除Access數(shù)詞庫(kù)中的空記錄用零長(zhǎng)度字符指示不存在數(shù)據(jù) 若要在 Microsoft Access 數(shù)據(jù)庫(kù)中指示不存在數(shù)據(jù),可以在“文本”或“備注”字段輸入零長(zhǎng)度字符串 (零長(zhǎng)度字符串:不含字符的字符串�?梢允褂昧汩L(zhǎng)度字符串來(lái)表明您知道該字段沒(méi)有值。輸入零長(zhǎng)度字符串的方法是鍵入兩個(gè)彼此之
下面提供的的方法分別適用使用虛擬主機(jī)空間的用戶(hù)和有IIS控制權(quán)的用戶(hù)!一:購(gòu)買(mǎi)虛擬主機(jī)空間的,適合沒(méi)有IIS控制權(quán)
1:發(fā)揮你的想象力 修改數(shù)據(jù)庫(kù)文件名
這個(gè)是最基本的。我想現(xiàn)在也沒(méi)有多少連數(shù)據(jù)庫(kù)文件名都懶得改的人吧? 至于改成什么,你自己看著辦,至少要保證文件名復(fù)雜,不可猜測(cè)性。當(dāng)然這個(gè)時(shí)候你的數(shù)據(jù)庫(kù)所在目錄是不能開(kāi)放目錄瀏覽權(quán)限的!
2:數(shù)據(jù)庫(kù)名后綴改為ASA、ASP等
這個(gè)聽(tīng)說(shuō)很流行,不過(guò)我測(cè)試了好多次,發(fā)現(xiàn)并不理想,如果真正要起到防止下載的作用,要進(jìn)行一些2進(jìn)制字段添加等設(shè)置,---一句話(huà),繁而復(fù)雜(如果你的數(shù)據(jù)庫(kù)有很多的話(huà),這個(gè)方法實(shí)在不是很好)
3:數(shù)據(jù)庫(kù)名前加“#”
只需要把數(shù)據(jù)庫(kù)文件前名加上#、然后修改數(shù)據(jù)庫(kù)連接文件(如conn.asp)中的數(shù)據(jù)庫(kù)地址。原理是下載的時(shí)候只能識(shí)別 #號(hào)前名的部分,對(duì)于后面的自動(dòng)去掉,比如你要下載:http://www.pcdigest.com/date/#123.mdb(假設(shè)存在的話(huà))。無(wú)論是IE還是FLASHGET等下到的都是http://www.pcdigest.com/date/index.htm(index.asp、default.jsp等你在IIS設(shè)置的首頁(yè)文檔)
另外在數(shù)據(jù)庫(kù)文件名中保留一些空格也起到類(lèi)似作用,由于HTTP協(xié)議對(duì)地址解析的特殊性,空格會(huì)被編碼為"%",如http://www.pcdigest.com/date/123 ;456.mdb,下載的時(shí)http://www.pcdigest.com/date/123%456.mdb。而我們的目錄就根本沒(méi)有123%456.mdb這個(gè)文件,所以下載也是無(wú)效的這樣的修改后,即使你暴露了數(shù)據(jù)庫(kù)地址,一般情況下別人也是無(wú)法下載!
4:加密數(shù)據(jù)庫(kù)
用ACCESS將你的數(shù)據(jù)庫(kù)以獨(dú)占方式打開(kāi)后,在工具-安全-設(shè)置數(shù)據(jù)庫(kù)密碼,加密后要修改數(shù)據(jù)庫(kù)連接頁(yè), 如:
conn.open "driver={microsoft access driver (*.mdb)};uid=admin;pwd=數(shù)據(jù)庫(kù)密碼;dbq=數(shù)據(jù)庫(kù)路徑"
這樣修改后,數(shù)據(jù)庫(kù)即使被人下載了,別人也無(wú)法打開(kāi)(前提是你的數(shù)據(jù)庫(kù)連接頁(yè)中的密碼沒(méi)有被泄露)
但值得注意的是,由于Access數(shù)據(jù)庫(kù)的加密機(jī)制比較簡(jiǎn)單,即使設(shè)置了密碼,解密也很容易。該數(shù)據(jù)庫(kù)系統(tǒng)通過(guò)將用戶(hù)輸入的密碼與某一固定密鑰進(jìn)行“異或”來(lái)形成一個(gè)加密串,并將其存儲(chǔ)在*.mdb文件從地址“&H42”開(kāi)始的區(qū)域內(nèi)。所以一個(gè)好的程序員可以輕松制作一個(gè)幾十行的小程序就可以輕松地獲得任何Access數(shù)據(jù)庫(kù)的密碼。因此,只要數(shù)據(jù)庫(kù)被下載,其信息安全依然是個(gè)未知數(shù)。
二:有主機(jī)控制權(quán) (當(dāng)然虛擬空間的設(shè)置在這里依然可以用)
5:數(shù)據(jù)庫(kù)放在WEB目錄外
如你的WEB目錄是e:\webroot,可以把數(shù)據(jù)庫(kù)放到e:\data這個(gè)文件夾里,在e:\webroot里的數(shù)據(jù)庫(kù)連接頁(yè)中修改數(shù)據(jù)庫(kù)連接地址為:"../data/數(shù)據(jù)庫(kù)名" 的形式,這樣數(shù)據(jù)庫(kù)可以正常調(diào)用,但是無(wú)法下載的,因?yàn)樗辉赪EB目錄里!這個(gè)方法一般也不適合購(gòu)買(mǎi)虛擬空間的用戶(hù)。
6:使用ODBC數(shù)據(jù)源
在ASP等程序設(shè)計(jì)中,如果有條件,應(yīng)盡量使用ODBC數(shù)據(jù)源,不要把數(shù)據(jù)庫(kù)名寫(xiě)在程序中,否則,數(shù)據(jù)庫(kù)名將隨ASP源代碼的失密而一同失密,例如: DBPath = Server.MapPath(“../123/abc/asfadf.mdb ”)
conn.open “driver={Microsoft Access Driver (*.mdb)};dbq=”& DBPath
可見(jiàn),即使數(shù)據(jù)庫(kù)名字起得再怪異,隱藏的目錄再深,ASP源代碼失密后,也很容易被下載下來(lái)。如果使用ODBC數(shù)據(jù)源,就不會(huì)存在這樣的問(wèn)題了: conn.open “ODBC-DSN名” ,不過(guò)這樣是比較煩的,目錄移動(dòng)的話(huà)又要重新設(shè)置數(shù)據(jù)源了,更方便的方法請(qǐng)看第7,8法!
7:添加數(shù)據(jù)庫(kù)名的如MDB的擴(kuò)展映射
這個(gè)方法就是通過(guò)修改IIS設(shè)置來(lái)實(shí)現(xiàn),適合有IIS控制權(quán)的朋友,不適合購(gòu)買(mǎi)虛擬主機(jī)用戶(hù)(除非管理員已經(jīng)設(shè)置了)。這個(gè)方法我認(rèn)為是目前最好的。只要修改一處,整個(gè)站點(diǎn)的數(shù)據(jù)庫(kù)都可以防止被下載。無(wú)須修改代碼即使暴露目標(biāo)地址也可以防止下載,如圖設(shè)置:

我們?cè)?IIS屬性---主目錄---配置---映射---應(yīng)用程序擴(kuò)展那里添加.mdb文件的應(yīng)用解析。注意這里的選擇的DLL(或EXE等)似乎也不是任意的,選擇不當(dāng),這個(gè)MDB文件還是可以被下載的, 注意最好不要選擇選擇asp.dll等。你可以自己多測(cè)試下
這樣修改后下載數(shù)據(jù)庫(kù)如:http://192.168.1.5/HaoBbs/data/dvbbs6.mdb。就出現(xiàn)(404或500等錯(cuò)誤)
8:使用.net的優(yōu)越性
動(dòng)網(wǎng)的木鳥(niǎo)就寫(xiě)過(guò)一個(gè)防非法下載文件的“WBAL 防盜鏈工具”。具體可以登陸http://www.9seek.com/WBAL/ ;
不過(guò) 那個(gè)只實(shí)現(xiàn)了防止非本地下載的 ,沒(méi)有起到真正的防下載數(shù)據(jù)庫(kù)的功能。不過(guò)這個(gè)方法已經(jīng)跟5法差不多可以通過(guò)修改.NET文件,實(shí)現(xiàn)本地也不能下載!
這幾個(gè)方法中,只有第7和8個(gè)是統(tǒng)一性改的,一次修改配置后,整個(gè)站點(diǎn)的數(shù)據(jù)庫(kù)都可以防止下載,其他幾個(gè)就要分別修改數(shù)據(jù)庫(kù)名和連接文件,比較麻煩,不過(guò)對(duì)于虛擬主機(jī)的朋友也只能這樣了!
其實(shí)第6個(gè)方法應(yīng)該是第5個(gè)方法的擴(kuò)展,可以實(shí)現(xiàn)特殊的功能,但對(duì)于不支持.net的主機(jī)或者怕設(shè)置麻煩的話(huà),還是直接用第5個(gè)方法了,而且默認(rèn)情況下第6個(gè)方法,依然可以通過(guò)復(fù)制連接到同主機(jī)的論壇或留言本發(fā)表,然后就可以點(diǎn)擊下載了(因?yàn)檫@樣的引用頁(yè)是來(lái)自同主機(jī)的)
這幾個(gè)方法各有長(zhǎng)短,請(qǐng)自己選擇性地使用。這些方法也不是絕對(duì)的安全,還需要網(wǎng)站管理員平時(shí)注意一些系統(tǒng)的安全,以及寫(xiě)ASP/ASP.NET/JSP代碼本身的安全 ,否則依然是有可能被人下載或者修改數(shù)據(jù)庫(kù)的!
分享:談Access數(shù)據(jù)庫(kù)在線壓縮的實(shí)現(xiàn)如果在 Access 數(shù)據(jù)庫(kù)中刪除數(shù)據(jù)或?qū)ο�,或者�?Access 項(xiàng)目中刪除對(duì)象,Access 數(shù)據(jù)庫(kù)或 Access 項(xiàng)目可能會(huì)產(chǎn)生碎片并會(huì)降低磁盤(pán)空間的使用效率。壓縮 Access 數(shù)據(jù)庫(kù)或Access項(xiàng)目實(shí)際上是復(fù)制該文件,并重新組織文件在磁盤(pán)上的存儲(chǔ)方式。壓縮同時(shí)優(yōu)化了 Acce
- Access數(shù)據(jù)庫(kù)安全策略之ASP式
- 第N次被ACCESS的關(guān)鍵字涮
- Access中用Jet SQL語(yǔ)句刪除表關(guān)系
- Access報(bào)表打印如何自動(dòng)分頁(yè)
- Access完成累計(jì)余額的計(jì)算
- 搭建Access為主的Mdb數(shù)據(jù)庫(kù)
- 一句sql更新兩個(gè)表并可更新對(duì)應(yīng)的字段值具體實(shí)現(xiàn)
- MySQL查詢(xún)優(yōu)化:連接查詢(xún)排序limit(join、order by、limit語(yǔ)句)介紹
- 內(nèi)網(wǎng)ssh/mysql登錄緩慢的解決方法
- 使用準(zhǔn)則進(jìn)行條件查詢(xún)--1.4.從窗體中選擇查詢(xún)的條件
- 中文Access2000速成教程--1.1 使用“向?qū)А痹O(shè)計(jì)數(shù)據(jù)庫(kù)
- 中文Access2000速成教程--1.3 在“設(shè)計(jì)”視圖中設(shè)計(jì)表
Access數(shù)據(jù)庫(kù)教程Rss訂閱編程教程搜索
Access數(shù)據(jù)庫(kù)教程推薦
- 解讀在ACCESS中調(diào)用后臺(tái)存儲(chǔ)過(guò)程
- PHP高級(jí)技巧:使用PHP模擬HTTP認(rèn)證
- 網(wǎng)絡(luò)數(shù)據(jù)庫(kù)站點(diǎn)防黑措施
- 如何防止Access 2000密碼被破
- 如何打開(kāi)老版本數(shù)據(jù)庫(kù)
- 談Access數(shù)據(jù)庫(kù)在線壓縮的實(shí)現(xiàn)
- Access數(shù)據(jù)庫(kù)開(kāi)發(fā)技巧(一)
- Access中用Jet SQL語(yǔ)句刪除表關(guān)系
- 如何讓asp和access數(shù)據(jù)庫(kù)連接?
- Access使用宏控制程序之創(chuàng)建宏
猜你也喜歡看這些
- 帶你深入了解Access數(shù)據(jù)庫(kù)的4種安全方式
- 詳解如何遠(yuǎn)程調(diào)用Access數(shù)據(jù)庫(kù)
- 數(shù)據(jù)庫(kù)設(shè)計(jì)范式
- C# 連接Access數(shù)據(jù)時(shí)總報(bào)找不到dbo.mdb的問(wèn)題
- 談Access:數(shù)據(jù)轉(zhuǎn)換問(wèn)題
- 高手支招ASP及Access的安全隱患及對(duì)策
- access下如何恢復(fù)已經(jīng)刪除的記錄;如何恢復(fù)已經(jīng)刪除的表、窗體等等對(duì)象
- 使ACCESS數(shù)據(jù)庫(kù)保持同步
- 解答Perl下應(yīng)當(dāng)如何連接Access數(shù)據(jù)庫(kù)
- 解讀Access報(bào)表打印——自動(dòng)分頁(yè)
- 相關(guān)鏈接:
- 教程說(shuō)明:
Access數(shù)據(jù)庫(kù)教程-解讀八種方法防止數(shù)據(jù)庫(kù)被下載
。