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

首頁 > 編程 > 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() 
%>
 
 
 
 
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产99久久精品一区二区 夜夜躁日日躁| 伊人久久男人天堂| 亚洲精品一区中文字幕乱码| 日韩有码片在线观看| 97久久精品人搡人人玩| 久久久久国产视频| 精品久久久久久久久久久久| 成人xxxxx| 中文字幕亚洲一区| 久久久久久久久爱| 欧美色xxxx| 欧美裸体xxxxx| 国产一区二区三区久久精品| 欧美区在线播放| 韩国国内大量揄拍精品视频| 久久精品国产精品| 色哟哟入口国产精品| 精品视频偷偷看在线观看| 中文字幕国产亚洲| 亚洲电影免费观看高清完整版| 国产亚洲人成网站在线观看| 亚洲精品福利免费在线观看| 国产精品美女免费视频| 精品色蜜蜜精品视频在线观看| 国语自产精品视频在线看抢先版图片| 欧美xxxx14xxxxx性爽| 亚洲天堂男人天堂| 国产成人鲁鲁免费视频a| 亚洲精品第一页| 欧美香蕉大胸在线视频观看| 国产精品一区二区在线| 亚洲午夜精品久久久久久性色| 九九精品在线播放| 亚洲国产中文字幕久久网| 久久综合久久八八| 亚洲精品美女在线观看| 91在线免费视频| zzjj国产精品一区二区| 亚洲第一区中文字幕| 亚洲精品av在线| 亚洲精品一区二区网址| 欧美日韩一区二区三区在线免费观看| 国产性色av一区二区| 欧美激情小视频| 国产成人综合精品在线| 国产精品老女人视频| 久久久精品视频成人| 91av免费观看91av精品在线| 精品国产91久久久| 欧美激情视频在线观看| 亚洲精品久久久久久久久久久久| 国产综合色香蕉精品| 亚洲一区二区中文字幕| 国产精品美女www爽爽爽视频| 欧美刺激性大交免费视频| 欧美国产一区二区三区| 亚洲最大成人在线| 国模视频一区二区三区| 国产精品视频自在线| 全球成人中文在线| 国产精品国模在线| 琪琪亚洲精品午夜在线| 欧美性极品少妇精品网站| 热久久这里只有精品| 久久久久久久久久国产精品| 日韩亚洲一区二区| 日韩av最新在线观看| 国内偷自视频区视频综合| 亚洲欧洲美洲在线综合| 国产在线拍揄自揄视频不卡99| 欧美午夜精品伦理| 国产99视频精品免视看7| 欧美激情视频免费观看| 萌白酱国产一区二区| 成人性生交大片免费观看嘿嘿视频| 欧美日韩免费区域视频在线观看| 国产精品96久久久久久又黄又硬| 成人免费观看49www在线观看| 久久久久一本一区二区青青蜜月| 成人性生交大片免费看视频直播| 久久不射热爱视频精品| 亚洲性视频网址| 成人黄在线观看| 久久久噜噜噜久噜久久| 成人福利网站在线观看| 成人在线播放av| 日韩在线视频免费观看高清中文| 中文字幕日韩欧美精品在线观看| 国产suv精品一区二区三区88区| 欧美日韩国产va另类| 久久中文字幕在线| 日韩最新中文字幕电影免费看| 麻豆国产va免费精品高清在线| 国产精品免费视频久久久| 中文字幕最新精品| 亚洲精品xxx| 伊人久久大香线蕉av一区二区| 一区二区三区日韩在线| 在线观看91久久久久久| 亚洲人成电影在线观看天堂色| 成人黄色av播放免费| 色综合久久久888| 亚洲欧美中文另类| 日韩av网址在线| 国产噜噜噜噜噜久久久久久久久| 国产日韩精品电影| 久久精品成人欧美大片古装| 欧美一级淫片videoshd| 久久91亚洲精品中文字幕| 欧美另类老肥妇| 国产日韩专区在线| 亚洲成人精品久久久| 日本精品一区二区三区在线| 欧美性猛交xxxx富婆| 九九精品在线视频| 亚洲黄色成人网| 久久久久久久久久国产精品| 九九热这里只有精品6| 日韩欧美在线一区| 在线播放亚洲激情| 怡红院精品视频| 青青久久av北条麻妃海外网| 欧美丝袜美女中出在线| 国产亚洲人成网站在线观看| 亚洲第一天堂av| 日韩精品视频免费| 精品福利在线观看| 日韩精品久久久久久福利| 久久男人av资源网站| 精品久久久久久久大神国产| 国产精品免费久久久| 国产区亚洲区欧美区| 亚洲精品一区中文字幕乱码| 精品一区电影国产| 欧美国产第一页| 日韩风俗一区 二区| 91av在线国产| 成人黄色av网| 久久国产精品首页| 欧美日韩国产专区| 日韩中文字幕不卡视频| 国产午夜精品全部视频在线播放| 国产精品第3页| 超碰精品一区二区三区乱码| 中文字幕在线国产精品| 中文字幕av一区二区| 欧美电影免费观看高清完整| 亚洲欧洲在线看| 欧美理论电影在线播放| 欧美尤物巨大精品爽| 97av在线视频免费播放| 国内精品久久久久久影视8| 91亚洲国产成人久久精品网站| 亚洲成avwww人| 96pao国产成视频永久免费| 九九久久国产精品| 国产一区二区三区在线视频| 91精品啪aⅴ在线观看国产| 欧美最顶级丰满的aⅴ艳星| 国产日本欧美一区二区三区| 国产精品黄色影片导航在线观看| 欧美日韩中文字幕综合视频| 在线播放国产一区中文字幕剧情欧美| 久久中文精品视频|