婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ASP也使用ORM,給ASP上所有的SQL注入畫上句號

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

熱門標簽:西寧公司外呼系統平臺 徐州人工智能電銷機器人好用嗎 地圖標注宅基地 外呼系統還用卡么 智能電銷機器人適用于哪些行業 騰訊地圖標注商戶關閉 武漢營銷電話機器人軟件 地圖標注服務哪家好 長沙防封電銷卡品牌
一般寫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()
%>

標簽:巴彥淖爾 鷹潭 通遼 普洱 雅安 運城 通化 荊門

巨人網絡通訊聲明:本文標題《ASP也使用ORM,給ASP上所有的SQL注入畫上句號》,本文關鍵詞  ASP,也,使用,ORM,給,上,所,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP也使用ORM,給ASP上所有的SQL注入畫上句號》相關的同類信息!
  • 本頁收集關于ASP也使用ORM,給ASP上所有的SQL注入畫上句號的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 峨边| 温州市| 子长县| 广河县| 大渡口区| 于田县| 红河县| 灌云县| 大英县| 黄龙县| 吉木萨尔县| 时尚| 利辛县| 苍南县| 五大连池市| 嘉善县| 呼和浩特市| 阿拉善盟| 梅河口市| 盐池县| 沈阳市| 贞丰县| 嘉祥县| 易门县| 通河县| 武冈市| 南通市| 揭西县| 通海县| 兴义市| 兰坪| 无为县| 图们市| 八宿县| 芒康县| 姚安县| 康定县| 蕉岭县| 天台县| 邮箱| 确山县|