網(wǎng)絡(luò)數(shù)據(jù)庫站點(diǎn)防黑措施(2)_Access數(shù)據(jù)庫教程
推薦:解決用Access數(shù)據(jù)庫建站維護(hù)不便的問題選用Access作為建站數(shù)據(jù)庫,除了低成本的原因之外,主要是Access數(shù)據(jù)庫的易發(fā)布性,一個(gè)MDB文件就包括了全部的表和數(shù)據(jù),開發(fā)完后連同 網(wǎng)頁和ASP腳本一起上傳到網(wǎng)站上就可以了,開發(fā)工具也不少
4.加密數(shù)據(jù)庫
首先在選取"工具->安全->加密/解密數(shù)據(jù)庫,選取數(shù)據(jù)庫(如:employer.mdb),然后接確定,接 著會(huì)出現(xiàn)"數(shù)據(jù)庫加密后另存為"的窗口,存為:employer1.mdb。接著employer.mdb就會(huì)被編碼,然后存為 employer1.mdb..要注意的是,以上的動(dòng)作并不是對(duì)數(shù)據(jù)庫設(shè)置密碼,而只是對(duì)數(shù)據(jù)庫文件加以編碼,目的是為了防止他 人使用別的工具來查看數(shù)據(jù)庫文件的內(nèi)容。
接下來我們?yōu)閿?shù)據(jù)庫加密,首先以打開經(jīng)過編碼了的 e mployer1.mdb,在打開時(shí),選擇"獨(dú)占"方式。然后選取功能表的"工具->安全->設(shè)置數(shù)據(jù)庫密碼",& nbsp;接著輸入密碼即可。這樣即使他人得到了employer1.mdb文件,沒有密碼他是無法看到 emplo yer1.mdb的。
加密后要修改數(shù)據(jù)庫連接頁, 如:
conn.open "driver={microsoft access driver&nb sp;(*.mdb)};uid=admin;pwd=數(shù)據(jù)庫密碼;dbq=數(shù)據(jù)庫路徑"
這樣修改后,數(shù)據(jù)庫即使被人下載了,別人也無法打開(前提是你的數(shù)據(jù)庫連接頁中的密碼沒有被泄露)。
但值得注意的是,由于Access數(shù)據(jù)庫的加密機(jī)制比較簡單,即使設(shè)置了密碼,解密也很容易。該數(shù)據(jù)庫系統(tǒng)通過將用戶輸入的 密碼與某一固定密鑰進(jìn)行"異或"來形成一個(gè)加密串,并將其存儲(chǔ)在*.mdb文件從地址"&H42"開始的區(qū)域內(nèi)。所以一 個(gè)好的程序員可以輕松制作一個(gè)幾十行的小程序就可以輕松地獲得任何Access數(shù)據(jù)庫的密碼。因此,只要數(shù)據(jù)庫被下載,其信息安 全依然是個(gè)未知數(shù)。
5.數(shù)據(jù)庫放在WEB目錄外或?qū)?shù)據(jù)庫連接文件放到其他虛擬目錄下
如你的WEB目錄是e:webroot,可以把數(shù)據(jù)庫放到e:data這個(gè)文件夾里,在e:webroot里的數(shù)據(jù)庫 連接頁中修改數(shù)據(jù)庫連接地址為:"../data/數(shù)據(jù)庫名" 的形式,這樣數(shù)據(jù)庫可以正常調(diào)用,但是無法下載的,因 為它不在WEB目錄里!這個(gè)方法一般也不適合購買虛擬空間的用戶。
6.使用ODBC數(shù)據(jù)源
在ASP等程序設(shè)計(jì)中,如果有條件,應(yīng)盡量使用ODBC數(shù)據(jù)源,不要把數(shù)據(jù)庫名寫在程序中,否則,數(shù)據(jù)庫名將隨ASP源代碼 的失密而一同失密,例如: DBPath = Server.MapPath("../123/ abc/asfadf.mdb ")
conn.open "driver={Microsoft Access Driver&nb sp;(*.mdb)};dbq="& DBPath
可見,即使數(shù)據(jù)庫名字起得再怪異,隱藏的目錄再深,ASP源代碼失密后,也很容易被下載下來。如果使用ODBC數(shù)據(jù)源,就不 會(huì)存在這樣的問題了: conn.open "ODBC-DSN名" ,不過這樣是比較煩的,目 錄移動(dòng)的話又要重新設(shè)置數(shù)據(jù)源了,更方便的方法請(qǐng)看第7,8法!
7.添加數(shù)據(jù)庫名的如MDB的擴(kuò)展映射
這個(gè)方法就是通過修改IIS設(shè)置來實(shí)現(xiàn),適合有IIS控制權(quán)的朋友,不適合購買虛擬主機(jī)用戶(除非管理員已經(jīng)設(shè)置了)。這個(gè) 方法我認(rèn)為是目前最好的。只要修改一處,整個(gè)站點(diǎn)的數(shù)據(jù)庫都可以防止被下載。無須修改代碼即使暴露目標(biāo)地址也可以防止下載。&n bsp;
我們?cè)贗IS屬性---主目錄---配置---映射---應(yīng)用程序擴(kuò)展那里添加.mdb文件的應(yīng)用解析。注意這里的選擇的D LL(或EXE等)似乎也不是任意的,選擇不當(dāng),這個(gè)MDB文件還是可以被下載的, 注意最好不要選擇選 擇asp.dll等。你可以自己多測(cè)試下。
這樣修改后下載數(shù)據(jù)庫如:http://www.test.com/data/dvbbs6.mdb。就出現(xiàn)(404或50 0等錯(cuò)誤)
8:使用.net的優(yōu)越性
動(dòng)網(wǎng)的木鳥就寫過一個(gè)防非法下載文件的"WBAL 防盜鏈工具"。不過 那個(gè)只實(shí)現(xiàn)了防止非本地下載的 ,沒有起到真正的防下載數(shù)據(jù)庫的功能。不過這個(gè)方法已經(jīng)跟5法差 不多可以通過修改.NET文件,實(shí)現(xiàn)本地也不能下載!
這幾個(gè)方法中,只有第7和8個(gè)是統(tǒng)一性改的,一次修改配置后,整個(gè)站點(diǎn)的數(shù)據(jù)庫都可以防止下載,其他幾個(gè)就要分別修改數(shù)據(jù)庫 名和連接文件,比較麻煩,不過對(duì)于虛擬主機(jī)的朋友也只能這樣了!
其實(shí)第6個(gè)方法應(yīng)該是第5個(gè)方法的擴(kuò)展,可以實(shí)現(xiàn)特殊的功能,但對(duì)于不支持.net的主機(jī)或者怕設(shè)置麻煩的話,還是直接用第 5個(gè)方法了,而且默認(rèn)情況下第6個(gè)方法,依然可以通過復(fù)制連接到同主機(jī)的論壇或留言本發(fā)表,然后就可以點(diǎn)擊下載了(因?yàn)檫@樣的引 用頁是來自同主機(jī)的)
9.利用NTFS分區(qū)的文件權(quán)限設(shè)置(by percyboy)
我們已經(jīng)知道,ASP.NET 中使用 ADO.NET 訪問數(shù)據(jù)庫,通過 OleDb 的連接可以訪問 Access 數(shù)據(jù)庫— —我們非常常用的低端數(shù)據(jù)庫之一。本文討論了 ASP.NET 中可能看到的若干錯(cuò)誤提示,從中看到&nb sp;Access 2000 和 Access XP 創(chuàng)建的數(shù)據(jù)庫文件 ,在訪問出現(xiàn)錯(cuò)誤時(shí)會(huì)出現(xiàn)不太相同的錯(cuò)誤提示。希望對(duì)大家有所幫助。另一個(gè)要點(diǎn)是,希望通過此文,使大家對(duì) ASP. NET 中 Access 數(shù)據(jù)庫文件的 NTFS 權(quán)限設(shè)置有所新的認(rèn)識(shí) 。
空格方案就不必多說了,我在本機(jī)的試驗(yàn)證明,在瀏覽器地址欄中直接寫 http://localhost/test data.mdb 沒有任何問題很順利就下載到了這個(gè) test data.mdb
所以,可行的方法是首先給數(shù)據(jù)庫加密,其次,設(shè)置IIS的口令,然后編寫代碼察看的驗(yàn)證程序,最后將數(shù)據(jù)庫放到其他的目錄里去,最好有支持root以外的data文件夾.例如第一商務(wù)的虛擬主機(jī)就有這樣的服務(wù)。
分享:ACCESS轉(zhuǎn)化成SQL2000要注意的問題 很多朋友想用SQL2000數(shù)據(jù)庫的編程方法,但是卻又苦于自己是學(xué)ACCESS的,對(duì)SQL只是一點(diǎn)點(diǎn)的了解而已,這里我給大家提供以下參考---將ACCESS轉(zhuǎn)化成SQL2000的方法和注意事項(xiàng) 一,首先,
- Access數(shù)據(jù)庫安全策略之ASP式
- 第N次被ACCESS的關(guān)鍵字涮
- Access中用Jet SQL語句刪除表關(guān)系
- Access報(bào)表打印如何自動(dòng)分頁
- Access完成累計(jì)余額的計(jì)算
- 搭建Access為主的Mdb數(shù)據(jù)庫
- 一句sql更新兩個(gè)表并可更新對(duì)應(yīng)的字段值具體實(shí)現(xiàn)
- MySQL查詢優(yōu)化:連接查詢排序limit(join、order by、limit語句)介紹
- 內(nèi)網(wǎng)ssh/mysql登錄緩慢的解決方法
- 使用準(zhǔn)則進(jìn)行條件查詢--1.4.從窗體中選擇查詢的條件
- 中文Access2000速成教程--1.1 使用“向?qū)А痹O(shè)計(jì)數(shù)據(jù)庫
- 中文Access2000速成教程--1.3 在“設(shè)計(jì)”視圖中設(shè)計(jì)表
Access數(shù)據(jù)庫教程Rss訂閱編程教程搜索
Access數(shù)據(jù)庫教程推薦
- 使用Access提高企業(yè)管理器功能
- 揭秘在設(shè)計(jì)視圖中Access允許的九種數(shù)據(jù)類型
- 怎樣為Access數(shù)據(jù)庫表添加日期或時(shí)間戳
- 數(shù)據(jù)在Access與Office組件間自由流動(dòng)
- Access中批量替換數(shù)據(jù)庫內(nèi)容的兩種方法
- 解讀access處理重復(fù)記錄的方法
- Access 2007通過查詢來計(jì)算累計(jì)余額
- 用Access設(shè)計(jì)客觀試卷(3)
- 在VB中動(dòng)態(tài)創(chuàng)建數(shù)據(jù)庫
- C# 連接Access數(shù)據(jù)時(shí)總報(bào)找不到dbo.mdb的問題
- 相關(guān)鏈接:
- 教程說明:
Access數(shù)據(jù)庫教程-網(wǎng)絡(luò)數(shù)據(jù)庫站點(diǎn)防黑措施(2)
。