亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > ASP > 正文

推薦一篇不錯的新手asp編程的基本法則

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

conn.execute "update Counts set counts='"&counts&"' where id='"&id&"'" '錯誤寫法 
conn.execute "update Counts set counts='"&counts&"' where id="&id '正確寫法 

二、ACCESS 數據庫連接 
通常數據庫連接有兩種方式,新手基本不知道用哪一種方式,或者在什么情況下用哪一種,又或者不知道兩者的原理 
①直接連接數據庫文件 


Set conn = Server.CreateObject("ADODB.Connection") 
conn.Open "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ="&Server.MapPath("database/yanhang.mdb") 

②通過數據源來連接數據庫文件 


Set conn = Server.CreateObject("ADODB.Connection") 
conn.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="&Server.MapPath("database/yanhang.mdb") 

那么,兩者到底哪一個好呢,當然是第二種,因為第一種其實就是客戶端瀏覽器直接讀取數據庫的,所以安全方面差很多,第二種通過數據源連接,是以服務器數據源工具連接的,與客戶端沒關系,所以數據庫不會暴露給客戶端,安全系數高很多。 

ACCESS 數據庫對應程序的應用:①直接連接數據庫文件 


conn.Open "DRIVER={Microsoft Access Driver (*.mdb)}; DBQ="&Server.MapPath("database/yanhang.mdb") 

這樣的數據庫連接方式,添加語句: 


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 數據庫對應程序的應用:②通過數據源來連接數據庫文件 


conn.Open "Provider=Microsoft.Jet.OLEDB.4.0; Data Source="&Server.MapPath("database/yanhang.mdb") 

這樣的數據庫連接方式,添加語句: 


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 

三、雙引號的應用 
通常我們寫超級連接這樣 <a href="abc.asp?id=<%=rs("id")%>">超級連接</a> 
但要是把這個超級連接編譯進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>" '(錯誤寫法) 

表單編譯進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")&"" />" '(錯誤寫法) 
新手asp編程的基本法則
 
 
 

四、防止ACCESS數據庫被下載的幾個方法 
很多動態站點大量應用了數據庫,數據庫理所當然成了一個站點的核心文件。一旦數據庫被非法下載,極有可能被惡意人士破壞網站?;蛘吒`取資料。 

下面提供的方法分別適用使用虛擬主機空間的用戶和有IIS控制權的用戶! 

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

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

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

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

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


二:有主機控制權 (當然虛擬空間的設置在這里依然可以用) 
5:數據庫放在WEB目錄外 
如你的WEB目錄是e:/webroot,可以把數據庫放到e:/data這個文件夾里,在e:/webroot里的數據庫連接頁中 
修改數據庫連接地址為:"../data/#123 456.mdb" 的形式,這樣數據庫可以正常調用,但是無法下載的,因為它不在WEB目錄里!這個方法一般也適合購買虛擬空間的用戶。 

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

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

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

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

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

其實第6種方法應該是第5種方法的擴展,可以實現特殊的功能,但對于不支持.net的主機或者怕設置麻煩的話,還是直接用第5種方法了,而且默認情況下第6種方法,依然可以通過復制連接到同主機的論壇或留言本發表,然后就可以點擊下載了(因為這樣的引用頁是來自同主機的) 

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色在人av网站天堂精品| 97视频在线看| 成人黄色av播放免费| 久久久久久久一| 成人夜晚看av| 亚洲专区国产精品| 欧美乱大交xxxxx| 日韩欧美在线中文字幕| 97人人模人人爽人人喊中文字| 色噜噜狠狠狠综合曰曰曰88av| 91久久久亚洲精品| 亚洲美女视频网站| 亚洲精品mp4| 久久免费少妇高潮久久精品99| 亚洲第一福利视频| 成人h片在线播放免费网站| 欧美黑人xxx| 亚洲综合在线做性| 久久久亚洲国产天美传媒修理工| 亚洲经典中文字幕| 亚洲欧美国产精品久久久久久久| 欧美一级大片在线观看| 中文字幕av一区中文字幕天堂| 午夜精品一区二区三区av| 欧美成人激情视频免费观看| 国产视频久久久久久久| 久久99久久久久久久噜噜| 亚洲免费一级电影| 欧洲日本亚洲国产区| 久久精品视频在线| 欧美国产日韩中文字幕在线| 久久影视电视剧免费网站| 亚洲欧美国产高清va在线播| 亚洲白虎美女被爆操| 日韩精品一区二区视频| 97超碰国产精品女人人人爽| 亚洲一区二区三区在线视频| 亚洲护士老师的毛茸茸最新章节| 亚洲国产高清自拍| 欧美性xxxx18| 精品国模在线视频| 96pao国产成视频永久免费| 中文字幕日本精品| 亚洲精品v天堂中文字幕| 欧美日韩美女视频| 亚洲图片欧美日产| 日韩精品在线免费播放| 在线视频欧美性高潮| 欧美大片va欧美在线播放| 欧美亚洲激情视频| 国产v综合ⅴ日韩v欧美大片| 欧美成人在线影院| 色狠狠久久aa北条麻妃| 欧美韩日一区二区| 欧美性受xxxx黑人猛交| 亚洲最大中文字幕| 国产精品久久久久福利| 国产第一区电影| 欧美日韩另类字幕中文| 疯狂欧美牲乱大交777| 亚洲奶大毛多的老太婆| 爱福利视频一区| 国产精品爽爽ⅴa在线观看| 国产精品成人在线| 亚洲色在线视频| 日韩精品视频在线播放| 久热精品视频在线免费观看| 91精品国产91久久| 欧美黄色三级网站| 欧美性猛交xxxx免费看漫画| 国产精品久久久久久久av电影| 中文字幕日韩高清| 久青草国产97香蕉在线视频| 91网站免费观看| 欧美午夜影院在线视频| 欧美日韩国产综合视频在线观看中文| 亚洲精品久久久久中文字幕二区| 午夜精品久久久久久久99热| 日韩精品在线第一页| 精品无人区太爽高潮在线播放| 久久亚洲欧美日韩精品专区| 精品久久国产精品| 成人精品福利视频| 亚洲理论电影网| 国产经典一区二区| 97在线视频免费播放| 在线观看日韩欧美| 国产在线98福利播放视频| 97在线精品国自产拍中文| 亚洲另类激情图| 欧美成人免费一级人片100| 亚洲电影免费观看高清完整版在线观看| 国产欧美久久一区二区| 久久免费国产精品1| 久久亚洲成人精品| 国产一区视频在线播放| 欧美黑人xxxⅹ高潮交| 久久久久久午夜| 国产精品久久久久久久美男| 美女福利精品视频| 亚洲色图偷窥自拍| 久久高清视频免费| 亚洲图片制服诱惑| 欧美精品aaa| 国产激情综合五月久久| 最新中文字幕亚洲| 国产成人精品午夜| 51久久精品夜色国产麻豆| 亚洲欧美国产精品| 欧洲亚洲女同hd| 久久精视频免费在线久久完整在线看| 欧美电影院免费观看| 国产精品久久久久久久久粉嫩av| 久久久久久综合网天天| 在线观看国产成人av片| 91人人爽人人爽人人精88v| 欧美性生交xxxxx久久久| 国产午夜精品全部视频在线播放| 亚洲tv在线观看| 日韩精品中文字幕在线播放| 亚洲综合精品伊人久久| 日韩欧美aaa| 国产一区二区丝袜| 成人欧美一区二区三区在线湿哒哒| 日韩免费中文字幕| 国产成人一区二区三区电影| 国产91对白在线播放| 日韩成人av在线| 精品成人国产在线观看男人呻吟| 91国内揄拍国内精品对白| 亚洲国产欧美久久| 国产91精品视频在线观看| 国产免费一区视频观看免费| 久久精品青青大伊人av| 国产精品视频免费观看www| 日韩精品视频在线观看免费| 亚洲一区二区久久久| 国产精品久久久久久五月尺| 欧美在线视频a| 久久久久中文字幕2018| 精品福利在线视频| 国产精品香蕉在线观看| 国产精品久久久999| 色哟哟亚洲精品一区二区| 91精品国产乱码久久久久久蜜臀| 国产精品主播视频| 97人人做人人爱| 亚洲国产小视频在线观看| 26uuu日韩精品一区二区| 亚洲片在线观看| 国产亚洲在线播放| 国产精品美女呻吟| 久久精品久久精品亚洲人| 欧美日韩中国免费专区在线看| 亚洲国产欧美日韩精品| 深夜福利91大全| 97精品国产91久久久久久| 亚洲精品视频中文字幕| 精品一区二区三区四区| 欧美精品日韩www.p站| 国产中文欧美精品| 日韩av免费在线观看| 亚洲免费av网址| 亚洲视频电影图片偷拍一区|