一、密碼式
給數(shù)據(jù)庫(kù)起一個(gè)隨機(jī)復(fù)雜的名稱(chēng),避免被猜到被下載,這種方式在以前很流行,因?yàn)榇蠹叶紝?duì)自己的代碼很有自信。但隨著錯(cuò)誤提示對(duì)數(shù)據(jù)庫(kù)地址的泄露導(dǎo)致數(shù)據(jù)庫(kù)被非法下載,這種方式也就越來(lái)越少人用了。
二、"#"式
在數(shù)據(jù)庫(kù)名稱(chēng)里加上#號(hào),從URL上請(qǐng)求時(shí)#是請(qǐng)求地址和請(qǐng)求參數(shù)的一個(gè)分隔字符,如果知道了數(shù)據(jù)庫(kù)名,直接請(qǐng)求的話(huà),如:
http://www.xx.com/access#.mdb,WEB服務(wù)器會(huì)認(rèn)為請(qǐng)求的是access而不是access#.mdb,所以會(huì)提示找不到文件,但是很遺憾,URL中對(duì)于這些特殊的字符都會(huì)有一個(gè)特殊的表示方式,#的特殊表示就是%23,如
http://www.xx.com/access%23.mdb,那么access#.mdb將會(huì)被下載。還有如果用FlashGet之類(lèi)的下載工具也可以直接下載。
三、ASP式
這種作法是比較專(zhuān)業(yè)但也是很安全的也是現(xiàn)在比較流行的作法,但是現(xiàn)在許多的人只是作了一半,只是將數(shù)據(jù)名改成ASP而以,這樣的話(huà)直接用FlashGet之類(lèi)的下載工具一樣可以將數(shù)據(jù)庫(kù)下載,這種方式的正確作法有兩步:
第一步:在數(shù)據(jù)庫(kù)內(nèi)創(chuàng)建一個(gè)字段,名稱(chēng)隨意,類(lèi)型是OLE對(duì)象,內(nèi)容設(shè)置為單字節(jié)型的"<%",即(ASP代碼chrB(asc("<")) & chrB(asc("%"))的運(yùn)行結(jié)果)
第二步:將數(shù)據(jù)庫(kù)改名為ASP
這樣從URL上直接請(qǐng)求這個(gè)數(shù)據(jù)庫(kù)將會(huì)提示"缺少關(guān)閉腳本分隔符",從而拒絕下載,因?yàn)檫@個(gè)方式比較麻煩我在網(wǎng)上找了一段小代碼來(lái)完成OLE對(duì)象的插入工作,只要將數(shù)據(jù)庫(kù)名設(shè)置好,然后放在和數(shù)據(jù)庫(kù)內(nèi)一目錄運(yùn)行一下就可以了。
代碼全文數(shù)下:
<%
db="d.mdb" '這里改成您的數(shù)據(jù)庫(kù)地址
set conn=server.createobject("Adodb.Connection")
connstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="&Server.MapPath(db)
conn.open connstr
conn.execute("create table notdownload(notdown oleobject)")
set rs=server.createobject("adodb.recordset")
sql="select * from notdownload"
rs.open sql,conn,1,3
rs.addnew
rs("notdown").appendchunk(chrB(asc("<")) & chrB(asc("%")))
rs.update
rs.close
set rs=nothing
conn.close
set conn=nothing
%>
這段代碼運(yùn)行完之后將會(huì)在數(shù)據(jù)庫(kù)內(nèi)生成一個(gè)nodownload表,表內(nèi)字段是notdown。如果數(shù)據(jù)庫(kù)內(nèi)已有同名的數(shù)據(jù)表存在請(qǐng)將代碼內(nèi)的nodownload改成自己想要的數(shù)據(jù)表名即可。
四、asa式
這種方式的真諦是利用IIS對(duì)ASA文件的保護(hù),從而使得數(shù)據(jù)庫(kù)文件不能從URL上直接請(qǐng)求下載,但是這種方式被誤解成只要將文件后綴改成ASA就可以了。要知道IIS只是對(duì)global.asa這個(gè)文件名有請(qǐng)求保護(hù),所以這種方式只能將數(shù)據(jù)庫(kù)名設(shè)置為global.asa,而且要注意的是,設(shè)置成global.asa之后最好不要將其放在主機(jī)或虛擬目錄的根目錄里,不然會(huì)被IIS當(dāng)然正常的global.asa文件進(jìn)行嘗試運(yùn)行的。