国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 編程 > ASP > 正文

ASP也使用ORM,給ASP上所有的SQL注入畫上句號

2024-05-04 11:09:02
字體:
來源:轉載
供稿:網友
PS:KJ大牛寫的文章,昨天跟一朋友聊天的時候提到了ADO的command查詢,我竟然把這個東西給忘記了,看來記性真的是太差了,找到了kj大牛的文章,拜讀一下。
 
 
 
一般寫ASP PHP代碼的朋友都估計是采用直接操作SQL的吧~ 
看以下的代碼 
<% 
dim conn,rs 
set conn=CreateObject("Adodb.Connection") 
conn.open .... 
set rs=conn.execute("select * from news"); 
... 
遍歷 rs.... 
%> 
這樣實現速度快是肯定的了,但是在結構邏輯上面1條半條語句當然不覺得怎樣!語句多了問題也就來了! 
參數沒過濾啊,SQL存在注入啊等等~OK 現在我們來換個設計模型! 
采用 3層結構 + ORM 
ORM : OBJECT RELATION MAPPING 
那什么是 ORM技術呢? 熟悉JAVA .NET開發的朋友一定很清楚...就是對象關系映射 
把表映射為類 字段映射為屬性 而記錄則映射為對象...現在JAVA的ORM持久層框架N多 
例如hibernate ibatis EntityBean(EJB其中一種) 
那在ASP上面呢? 我們也一樣可以實現.等等介紹 
3層結構 : WEB展現層 中間層 持久層 
以下有一個news 的表 簡單一點的 
create table news( 
id int, 
title varchar(200), 
contect varchar(50000) 

我們把他映射為類 
<% 
Class News 
private id,title,contect 
Sub setID(sid) 
id=Cint(sid) 
End Sub 
Function getID 
getID=id 
End Function 
Sub setTitle(stitle) 
title=mid(stitle,1,200)'限制了長度 
End Sub 
.... 
End Class 
%> 
然后我們再設計如何操作數據庫轉換為對象的代碼 
<% 
Class NewsDataAccessObject 
dim conn,rs,cmd 
'查詢一篇新聞 
Function getNewsByID(id) 
set conn=Applcation("connection")'連接池里面獲取一個連接 
set cmd=GetCmd() ' GETCMD函數實現 return createobject("Adodb.Command") 
selectString="select * from NEWS where id = @id" 
cmd.ActiveConnection = conn 
cmd.CommandType = adCmdText ' Const adCmdText=1 
cmd.CommandText = selectString 
'為剛剛的的@id追加參數,常量 adInteger = 3 adParamInput=1 
cmd.Parameters.Append cmd.CreateParameter("@id", adInteger, adParamInput, , id) 
'運行SQL語句 返回結果集合 
set rs=cmd.execute() 
dim anews 
set anew=new News 
if rs.eof then 
else 
anew.setID(rs("id")&"") 
anew.setTitle(rs("title")&"") 
anew.setContect(rs("Contect")&"") 
end if 
rs.close 
set rs=nothing 
set cmd=nothing 
set conn=nothing 
set getNewsByID=anew 
End Function 
'插入一篇新聞 
Function addNews(anew) 
dim conn,cmd 
if isempty(anew) then addNews=false 
set conn=Applcation("connection")'連接池里面獲取一個連接 
set cmd=GetCmd() ' GETCMD函數實現 return createobject("Adodb.Command") 
insertString="insert into NEWS(id,title,contect) values( @id , @title , @contect )" 
cmd.ActiveConnection = conn 
cmd.CommandType = adCmdText ' Const adCmdText=1 
cmd.CommandText = insertString 
'為剛剛的的@id @title @contect追加參數,常量 adInteger = 3 adParamInput=1 adVarWChar = 202 
cmd.Parameters.Append cmd.CreateParameter("@id", adInteger, adParamInput, , anew.getID() ) 
cmd.Parameters.Append cmd.CreateParameter("@title",adVarWChar, adParamInput, 200 , anew.getTitle() ) 
cmd.Parameters.Append cmd.CreateParameter("@contect",adVarWChar, adParamInput, 50000 , anew.getConect() ) 
'運行SQL語句 
cmd.execute() 
set cmd=nothing 
set conn=nothing 
addNews=true 
End Function 
Function findByTitle(stitle) 
.... 
End Function 
Function getPageNews(page,size) 
.... 
End Function 
End Class 
%> 
以上就是對數據庫操作然后把結果封裝到對象里面 或者把對象寫入數據庫 
這樣實現雖然速度上面會稍慢 但是總體邏輯結構非常明顯,不需要關心變量是否已經給過濾或者多過濾 
而web頁面層的設計人員更多的關注于界面方面 
以下為提交添加新聞代碼 
<% 
dim id,title,contect,anew,dao 
id=Request("id") 
title=Request.Form("title") 
contect=Request.Form("contect") 
set anew=new NEWS 
anew.setID(id) 
anew.setTitle(title) 
anew.setContect(contect) 
set dao=new NewsDataAccessObject 
if dao.addNews(anew) then 
'response.write 
echo "success" 
else 
echo "error" 
end if 
%> 
把新聞查出來顯示 
<% 
dim id,dao,anew 
id=Request("id") 
set dao=new NewsDataAccessObject 
set anew=dao.getNewsByID(id) 
if anew.getID()<>"" then 
%> 
標題:<%=anew.getTitle()%> 
內容:<%=anew.getContect()%> 
..... 
以上片段代碼如有錯漏謝謝指點~~~ 
使用這樣的設計方式就根本不需要像XXXBLOG XXXBBS XXX文章系統那樣 
忘記Replace(SQL,"'","''") 而產生injection了! 
對于頁面的整潔性而言 也不會出現SQL語句,連接等 美工負責好自己的工作然后把對象的屬性放到相應的位置就OK 
而有可能有朋友會覺得 用戶認證方面呢!那更省事了把用戶表的用戶對象放到session里面就OK 
<% 
if isempty(session("user")) or session("user")="" then 
'跳轉 
else 
set auser=session("user") 
echo "歡迎你:" & auser.getName() 
%>
 
 
 
 
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
在线观看精品视频一区二区三区| 中文字幕av中文字幕| 91xxx在线观看| 成人欧美日韩| 国产国语**毛片高清视频| 国产二区三区在线| av在线第一页| 丁香花高清视频完整版在线观看| 黄色av网站在线| 中文字幕在线免费视频| 国产福利在线免费观看| 四虎影视成人永久免费观看视频| 欧美日韩一区二区三区在线播放| 九九热精品在线视频| 国产人成精品| 不卡av免费观看| 国产网站av| 午夜在线不卡| 国产高清视频在线| 丁香花高清在线观看完整版| 伊人影院蕉久影院在线播放| 国产免费黄色| 四虎网站在线观看| 18 激情视频在线| 五月天丁香在线| 超碰在线影院| www免费在线观看视频| 精品一区二区在线欧美| 国产亚洲精品拍拍拍拍拍| 亚洲成a人v欧美综合天堂麻豆| 国产女王在线**视频 | 亚洲精品一线| 中文字幕国产欧美| 免费观看久久久久| 操操操综合网| 久久久久久久久久久久久91| 亚洲精品影视在线| 精品国产高清自在线一区二区三区| 天天av综合网| 国产美女高潮一区二区三区| 久久精品蜜桃| 不卡av免费观看| 热99在线观看| 九九热视频免费在线观看| 日本成人网址| 天天操天天射天天色| 午夜av电影| 91极品在线| 日本在线视频www鲁啊鲁| av中文字幕在线看| 久久国产情侣| 国产男女av| 国产不卡在线| 日本电影在线观看| 激情五月色综合亚洲小说| 国产女人伦码一区二区三区不卡| 开心丁香婷婷深爱五月| 国产美女在线免费观看| 国产日产精品久久久久久婷婷| 96久久久久久| 欧美婷婷久久五月精品三区| 大香伊人久久| 亚洲第一成年免费网站| 免费男女羞羞的视频网站中文字幕| 欧美精品久久久久久久小说| 最新亚洲精品国自产在线观看| 精品美女视频在线观看免费软件| 性欧美精品xxxx| 国产午夜在线视频| 天天干天天摸| 国产videos| 高清欧美精品xxxxx在线看| 日本中文字幕高清视频| 国产福利小视频在线| 麻豆国产在线视频| 中文岛国精品亚洲一区| 国产在线播放av| 在线国产网址| 国产精品白浆流出视频| 国产91大片| 麻豆电影传媒二区| www.色五月| 91这里只有精品| 国产精品视频二区三区| 国产美女在线免费观看| 青青艹在线视频| 日本亚洲欧美| 国产成+人+亚洲+欧美+综合| 国产精选一区二区三区不卡催乳| av在线免费播放| 在线观看视频污| 在线亚洲精品自拍| 97视频免费| 2019年中文字幕| 2021av在线| 精品麻豆一区二区三区| 777电影在线观看| 国产高清自拍视频在线观看 | av免费在线观| 在线国产福利网站| 国产精品18久久久久久久久久| 九九热在线视频观看| 黄污在线观看| 五月伊人六月| 国产二区视频| 伊人222成人综合网| 精品剧情v国产在线观看| 精品一区二区三区在线观看l| 国产一二区在线观看| 国产精品视频h| 国产98在线| jlzzjlzz欧美| 九九久久久2| 中文字幕免费中文| 国产xxx在线| 日本亚洲欧美| 国产精品一区二区三区高清在线 | 国产一区二区三区不卡免费观看| 国产乱码在线| av大片在线播放| 国内精品不卡| 91青青在线视频| 免费精品国产自产拍观看| 99视频在线观看地址| 影音先锋在线中文字幕| 国产中文字幕在线观看| 精品国产福利一区二区在线 | 欧美日韩不卡中文字幕在线| 高清av中文在线字幕观看1| 国产精品美女一区二区三区四区| 在线看黄网址| 国产一级性片| wwww在线观看| 精品一二三四| 国产乱视频在线观看播放| 国产高清av在线| 中文字幕视频在线免费| av麻豆国产| 国产三级香港三韩国三级| 亚洲视频精品在线观看| 国产一级大片| 青青草视频在线观看| 国产精品国产国产aⅴ| 国产美女极品在线| 玖玖在线视频| jlzzjlzz欧美大全| 国产精品你懂的在线观看| 天天艹天天操| av亚洲男人天堂| 91中文字幕| 国产不卡在线| 国产激情视频在线观看| 中文字幕网在线| 国产区高清在线| 中文字幕在线视频不卡| 久久精品免视着国产成人| 亚洲成人av在线影院| 亚洲欧美一区二区三区在线播放| 国产精品欧美色图| 国产精品入口免费麻豆| 国产网站av| 国产福利在线观看| 国产95在线|亚洲| 国产成人天天5g影院| 国产精品白浆流出视频| 国产成人综合美国十次| 在线一二三区| 免费在线播放av| 另类视频在线| 国产中文在线| 国产区视频在线| 在线色视频网| 欧美日韩一区二区三区视视频| 免费a在线看| 中文字幕av中文字幕| 国产95在线|亚洲| jizz国产| 国产美女在线一区二区三区| 国产香蕉免费精品视频| 亚洲第一成年免费网站| 国产女人伦码一区二区三区不卡| 国产三级自拍| eeuss影院www在线播放| 九色精品视频在线观看| 国产麻豆精品入口在线观看 | 精品推荐蜜桃传媒| 本道综合精品| 国产精品第八页| 日本高清中文字幕在线| 国产一区二区三区四区尤物| 亚洲大香人伊一本线| 日本中文字幕视频在线| 亚洲人成影院在线| 国产午夜在线| 麻豆精品传媒视频观看| 992tv在线观看在线播放| 国产免费一级| 亚洲sss视频| 97一区二区三区| 中文字幕不卡免费视频|