一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達(dá)式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - ASP教程 - 新手asp編程的基本法則與常見錯誤注意事項(xiàng)

新手asp編程的基本法則與常見錯誤注意事項(xiàng)

2019-09-23 10:18asp教程網(wǎng) ASP教程

在論壇看到很多帖子代碼中都有一個共同的基本錯誤,字段類型錯誤。程序和數(shù)據(jù)庫是緊緊相連的,數(shù)據(jù)庫字段文本型或時間型的都使用單引號

一、新手常犯的錯誤 
在論壇看到很多帖子代碼中都有一個共同的基本錯誤,字段類型錯誤。 
程序和數(shù)據(jù)庫是緊緊相連的,數(shù)據(jù)庫字段文本型或時間型的都使用單引號 
比如下面這段修改語句: 
conn.execute "update Counts set counts='"&counts&"' where num="&num&" and Atime='"&now()&"'" 
等號左邊都是字段名,等號右邊是傳值過來的變量名,counts 字段是文本型,所以寫入時必須前后加單引號,無論是寫入還是查詢都一樣,后面的查尋語句中,num 字段是數(shù)字型,所以前后就沒有單引號了,Atime 字段是時間型所以前后也要加單引號。 
最重要的是以ID查詢,ID字段是唯一的并且數(shù)字類型,很明顯查詢ID號時前后也不能有單引號 
conn.execute "update Counts set counts='"&counts&"' where id='"&id&"'"  '錯誤寫法 
conn.execute "update Counts set counts='"&counts&"' where id="&id  '正確寫法 

二、ACCESS 數(shù)據(jù)庫連接 
通常數(shù)據(jù)庫連接有兩種方式,新手基本不知道用哪一種方式,或者在什么情況下用哪一種,又或者不知道兩者的原理 
①直接連接數(shù)據(jù)庫文件 
Set conn = Server.CreateObject("ADODB.Connection") 
conn.Open "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ="&Server.MapPath("database/yanhang.mdb") 

②通過數(shù)據(jù)源來連接數(shù)據(jù)庫文件 
Set conn = Server.CreateObject("ADODB.Connection") 
conn.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="&Server.MapPath("database/yanhang.mdb") 

那么,兩者到底哪一個好呢,當(dāng)然是第二種,因?yàn)榈谝环N其實(shí)就是客戶端瀏覽器直接讀取數(shù)據(jù)庫的,所以安全方面差很多,第二種通過數(shù)據(jù)源連接,是以服務(wù)器數(shù)據(jù)源工具連接的,與客戶端沒關(guān)系,所以數(shù)據(jù)庫不會暴露給客戶端,安全系數(shù)高很多。 

ACCESS 數(shù)據(jù)庫對應(yīng)程序的應(yīng)用:①直接連接數(shù)據(jù)庫文件 
conn.Open "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ="&Server.MapPath("database/yanhang.mdb") 
這樣的數(shù)據(jù)庫連接方式,添加語句: 
set rs=server.createobject("adodb.recordset")   '(正確寫法) 
rs.open "select * from dndj",conn,1,3 
rs.addnew 
rs("bh") = bh 
rs("bm") = bm 
rs("xm") = xm 
rs("xsq") = xsq 
rs.update 
rs.close 
set rs=nothing 

set rs=server.createobject("adodb.recordset")  '(錯誤寫法) 
sql="insert into dndj(bh,bm,xm,xsq) values('bh','bm','xm','xsq')" 
rs.open sql,conn,1,3 

ACCESS 數(shù)據(jù)庫對應(yīng)程序的應(yīng)用:②通過數(shù)據(jù)源來連接數(shù)據(jù)庫文件 
conn.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="&Server.MapPath("database/yanhang.mdb") 
這樣的數(shù)據(jù)庫連接方式,添加語句: 
conn.execute "insert into dndj(bh,bm,xm,xsq) values('"&bh&"','"&bm&"','"&xm&"','"&xsq&"')"    '(正確寫法) 

set rs=server.createobject("adodb.recordset")  '(錯誤寫法) 
sql="insert into dndj(bh,bm,xm,xsq) values('bh','bm','xm','xsq')" 
rs.open sql,conn,1,3 

三、雙引號的應(yīng)用 
通常我們寫超級連接這樣 <a href="abc.asp?id=<%=rs("id")%>">超級連接</a> 
但要是把這個超級連接編譯進(jìn)asp里面呢 
response.write "<a href=""abc.asp?id="&rs("id")&""">超級連接</a>"   '(正確寫法) 
response.write "<a href='abc.asp?id="&rs("id")&"'>超級連接</a>"       '(正確寫法) 
response.write "<a href=abc.asp?id="&rs("id")&">超級連接</a>"        '(正確寫法) 

response.write "<a href="abc.asp?id=<%=rs("id")%>">超級連接</a>"  '(錯誤寫法) 
response.write "<a href="abc.asp?id="&rs("id")&"">超級連接</a>"       '(錯誤寫法) 

表單編譯進(jìn)asp里  <input type="text" name="id" value="<%rs("id")%>" /> 
response.write "<input type=""text"" name=""id"" value="""&rs("id")&""" />" '(正確寫法) 注意:這里有三個雙引號 
response.write "<input type='text' name='id' value='"&rs("id")&"' />"       '(正確寫法) 
response.write "<input type=text name=id value="&rs("id")&" />"            '(正確寫法) 

response.write "<input type="text" name="id" value="<%=rs("id")%>" />"  '(錯誤寫法) 
response.write "<input type="text" name="id" value=""&rs("id")&"" />"       '(錯誤寫法) 

四、防止ACCESS數(shù)據(jù)庫被下載的幾個方法 
很多動態(tài)站點(diǎn)大量應(yīng)用了數(shù)據(jù)庫,數(shù)據(jù)庫理所當(dāng)然成了一個站點(diǎn)的核心文件。一旦數(shù)據(jù)庫被非法下載,極有可能被惡意人士破壞網(wǎng)站。或者竊取資料。 

下面提供的方法分別適用使用虛擬主機(jī)空間的用戶和有IIS控制權(quán)的用戶!  

   一:購買虛擬主機(jī)空間的,適合沒有IIS控制權(quán) 
1:發(fā)揮你的想象力 修改數(shù)據(jù)庫文件名 
這個是最基本的。我想現(xiàn)在也沒有多少連數(shù)據(jù)庫文件名都懶得改的人吧? 至于改成什么,你自己看著辦,至少要保證文件名復(fù)雜,不可猜測性。當(dāng)然這個時候你的數(shù)據(jù)庫所在目錄是不能開放目錄瀏覽權(quán)限的! 

2:數(shù)據(jù)庫名后綴改為ASA、ASP等 
這個聽說很流行,不過我測試了好多次,發(fā)現(xiàn)并不理想,如果真正要起到防止下載的作用,要進(jìn)行一些二進(jìn)制字段添加等設(shè)置,一句話,繁而復(fù)雜(如果你的數(shù)據(jù)庫有很多的話,這個方法實(shí)在不是很好) 

3:數(shù)據(jù)庫名前加“#” 
只需要把數(shù)據(jù)庫文件前名加上#、然后修改數(shù)據(jù)庫連接文件(如conn.asp)中的數(shù)據(jù)庫地址。原理是下載的時候只能識別 #號前名的部分,對于后面的自動去掉,比如你要下載:http://bbs.bccn.net/date/#123.mdb(假設(shè)存在的話)。無論是IE還是FLASHGET等下到的都是http://bbs.bccn.net/date/index.htm 

另外在數(shù)據(jù)庫文件名中保留一些空格也起到類似作用,由于HTTP協(xié)議對地址解析的特殊性,空格會被編碼為"%20",如http://bbs.bccn.net/date/123 456.mdb 
下載時http://bbs.bccn.net/date/123%20456.mdb。而我們的目錄就根本沒有123%20456.mdb這個文件,所以下載也是無效的,即使你暴露了數(shù)據(jù)庫地址,一般情況下別人也是無法下載,最好兩種方法同時使用“#”+空格,例如 http://bbs.bccn.net/date/#123 456.mdb 

4:加密數(shù)據(jù)庫 
用ACCESS將你的數(shù)據(jù)庫以獨(dú)占方式打開后,在工具-安全-設(shè)置數(shù)據(jù)庫密碼,加密后要修改數(shù)據(jù)庫連接頁, 如: 
conn.open "driver={microsoft access driver (*.mdb)};uid=admin;pwd=數(shù)據(jù)庫密碼;dbq=數(shù)據(jù)庫路徑" 
這樣修改后,數(shù)據(jù)庫即使被人下載了,別人也無法打開(前提是你的數(shù)據(jù)庫連接頁中的密碼沒有被泄露) 
但值得注意的是,由于Access數(shù)據(jù)庫的加密機(jī)制比較簡單,即使設(shè)置了密碼,解密也很容易。該數(shù)據(jù)庫系統(tǒng)通過將用戶輸入的密碼與某一固定密鑰進(jìn)行“異或”來形成一個加密串,并將其存儲在*.mdb文件從地址“&H42”開始的區(qū)域內(nèi)。所以一個好的程序員可以輕松制作一個幾十行的小程序就可以輕松地獲得任何Access數(shù)據(jù)庫的密碼。因此,只要數(shù)據(jù)庫被下載,其安全依然是個未知數(shù)。  


  二:有主機(jī)控制權(quán) (當(dāng)然虛擬空間的設(shè)置在這里依然可以用) 
5:數(shù)據(jù)庫放在WEB目錄外 
如你的WEB目錄是e:\webroot,可以把數(shù)據(jù)庫放到e:\data這個文件夾里,在e:\webroot里的數(shù)據(jù)庫連接頁中 
修改數(shù)據(jù)庫連接地址為:"../data/#123 456.mdb" 的形式,這樣數(shù)據(jù)庫可以正常調(diào)用,但是無法下載的,因?yàn)樗辉赪EB目錄里!這個方法一般也適合購買虛擬空間的用戶。 

6:使用ODBC數(shù)據(jù)源。 
在ASP等程序設(shè)計中,如果有條件,應(yīng)盡量使用ODBC數(shù)據(jù)源,不要把數(shù)據(jù)庫名寫在程序中,否則,數(shù)據(jù)庫名將隨ASP源代碼的失密而一同失密 
例如: 
conn.open "driver={Microsoft Access Driver (*.mdb)};dbq="&Server.MapPath("../123/abc/asfadf.mdb") 
可見,即使數(shù)據(jù)庫名字起得再怪異,隱藏的目錄再深,ASP源代碼失密后,也很容易被下載下來。 
如果使用ODBC數(shù)據(jù)源,就不會存在這樣的問題了:conn.open "ODBC-DSN名" ,不過這樣是比較煩的,目錄移動的話又要重新設(shè)置數(shù)據(jù)源了! 

7:添加數(shù)據(jù)庫名的如MDB的擴(kuò)展映射 
這個方法就是通過修改IIS設(shè)置來實(shí)現(xiàn),適合有IIS控制權(quán)的朋友,不適合購買虛擬主機(jī)用戶(除非管理員已經(jīng)設(shè)置了)。這個方法我認(rèn)為是目前最好的。只要修改一處,整個站點(diǎn)的數(shù)據(jù)庫都可以防止被下載。無須修改代碼即使暴露目標(biāo)地址也可以防止下載。 

設(shè)置: 
在 IIS屬性---主目錄---配置---映射---應(yīng)用程序擴(kuò)展那里添加.mdb文件的應(yīng)用解析。注意這里的選擇的DLL(或EXE等)似乎也不是任意的,選擇不當(dāng),這個MDB文件還是可以被下載的,  注意最好不要選擇選擇asp.dll等。你可以自己多測試下 
這樣修改后下載數(shù)據(jù)庫如:http://bbs.bccn.net/data/dvbbs6.mdb。就出現(xiàn)(404或500等錯誤) 

8:使用.net的優(yōu)越性 
動網(wǎng)的木鳥就寫過一個防非法下載文件的“WBAL 防盜鏈工具”。記得本論壇曾經(jīng)也有位牛人也發(fā)表過數(shù)據(jù)庫防下載的插件,是.dll的加載到IIS里的。 
不過 那個只實(shí)現(xiàn)了防止非本地下載的 ,沒有起到真正的防下載數(shù)據(jù)庫的功能。不過這個方法跟第5種差不多 
可以通過修改.NET文件,實(shí)現(xiàn)本地也不能下載! 

這幾個方法中,只有第7和8個是統(tǒng)一性改的,一次修改配置后,整個站點(diǎn)的數(shù)據(jù)庫都可以防止下載,其他幾個就要分別修改數(shù)據(jù)庫名和連接文件,比較麻煩,不過對于虛擬主機(jī)的朋友也只能這樣了! 

其實(shí)第6種方法應(yīng)該是第5種方法的擴(kuò)展,可以實(shí)現(xiàn)特殊的功能,但對于不支持.net的主機(jī)或者怕設(shè)置麻煩的話,還是直接用第5種方法了,而且默認(rèn)情況下第6種方法,依然可以通過復(fù)制連接到同主機(jī)的論壇或留言本發(fā)表,然后就可以點(diǎn)擊下載了(因?yàn)檫@樣的引用頁是來自同主機(jī)的) 

這幾個方法各有長短,請自己選擇性地使用。這些方法也不是絕對的安全,還需要網(wǎng)站管理員平時注意一些系統(tǒng)的安全,以及寫ASP代碼本身的安全 ,否則依然有可能被人下載或者修改數(shù)據(jù)庫! 

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 3黑人巨大vs北岛玲 3d肉浦团在线观看 3d动漫免费 | 日本免费久久久久久久网站 | 亚洲AV无码国产精品色在线看 | 动态图啪啪120秒免费看 | 四虎最新永久免费网址 | 四虎影院在线免费播放 | 果冻传媒九一制片厂 | 精品一区二区三区五区六区七区 | 被夫上司强迫中文 | 欧美国产日本精品一区二区三区 | 亚洲卡一卡2卡三卡4卡无卡三 | 午夜视频一区二区三区 | 欧美一级片免费看 | 免费观看韩剧网站在线观看 | 九九国产在线视频 | 性欧美13处丶14处 | 韩国甜性涩爱免费观看 | 色淫影院 | 公妇乱淫在线播放免费观看 | 98精品视频 | 动漫精品一区二区三区3d | 999久久精品国产 | 免费看日产一区二区三区 | 韩国黄色片网站 | 和直男装修工在工地啪 | 久久久久久久尹人综合网亚洲 | 国产欧美视频高清va在线观看 | 97国产影院| 波多洁野衣一二区三区 | 国产精品久久久久久久久久久搜索 | 欧美日韩一区二区三区免费不卡 | 红杏网| 公交车揉捏大乳呻吟喘娇 | 国产视频久久久久 | 精品国产品国语在线不卡丶 | 色卡7707c| 青青青在线视频播放 | juliaann厨房大战| 午夜精品久久久久 | 国产一区二区三区免费在线视频 | 女人和男人搞鸡 |