国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關注微信公眾號

防范SQL指令植入式攻擊
2008-04-24   

什么是SQL 指令植入式攻擊?

在設計或者維護Web 網站時,你也許擔心它們會受到某些卑鄙用戶的惡意攻擊。的確,如今的 Web 網站開發者們針對其站點所在操作系統平臺或Web 服務器的安全性而展開的討論實在太多了。不錯,IIS 服務器的安全漏洞可能招致惡意攻擊;但你的安全檢查清單不應該僅僅有 IIS 安全性這一條。有些代碼,它們通常是專門為數據驅動(data-driven) 的 Web 網站而設計的,實際上往往同其它 IIS 漏洞一樣存在嚴重的安全隱患。這些潛伏于代碼中的安全隱患就有可能被稱為“SQL 指令植入式攻擊” (SQL injection) 的手段所利用而導致服務器受到攻擊。

SQL 指令植入式攻擊技術使得攻擊者能夠利用 Web 應用程序中某些疏于防范的輸入機會動態生成特殊的 SQL 指令語句。舉一個常見的例子:

某Web 網站采用表單來收集訪問者的用戶名和密碼以確認他有足夠權限訪問某些保密信息,然后該表單被發送到 Web 服務器進行處理。接下來,服務器端的ASP 腳本根據表單提供的信息生成 SQL 指令語句提交到 SQL 服務器,并通過分析SQL 服務器的返回結果來判斷該用戶名/密碼組合是否有效。

為了實現這樣的功能,Web 程序員可能會設計兩個頁面:一個 HTML 頁面 (Login.htm) 用于登錄,另一個ASP 頁面 (ExecLogin.asp) 用于驗證用戶權限(即向數據庫查詢用戶名/密碼組合是否存在)。具體代碼可能象這樣:

Login.htm (HTML 頁面)

代碼:<form action="ExecLogin.asp" method="post"> Username: <input type="text" name="txtUsername"><br> Password: <input type="password" name="txtPassword"><br> <input type="submit"> </form>

ExecLogin.asp (ASP 頁面)  代碼:<% Dim p_strUsername, p_strPassword, objRS, strSQL p_strUsername = Request.Form("txtUsername") p_strPassword = Request.Form("txtPassword") strSQL = "SELECT * FROM tblUsers " & _ "WHERE Username=" & p_strUsername & _ " and Password=" & p_strPassword & "" Set objRS = Server.CreateObject("ADODB.Recordset") objRS.Open strSQL, "DSN=..." If (objRS.EOF) Then Response.Write "Invalid login." Else Response.Write "You are logged in as " & objRS("Username") End If Set objRS = Nothing %>

乍一看,ExecLogin.asp 的代碼似乎沒有任何安全漏洞,因為用戶如果不給出有效的用戶名/密碼組合就無法登錄。然而,這段代碼偏偏不安全,而且它正是SQL 指令植入式攻擊的理想目標。具體而言,設計者把用戶的輸入直接用于構建SQL 指令,從而使攻擊者能夠自行決定即將被執行的 SQL 指令。例如:攻擊者可能會在表單的用戶名或密碼欄中輸入包含“ or ”和“=” 等特殊字符。于是,提交給數據庫的 SQL 指令就可能是:  代碼:SELECT * FROM tblUsers WHERE Username= or = and Password = or =

這樣,SQL 服務器將返回 tblUsers 表格中的所有記錄,而 ASP 腳本將會因此而誤認為攻擊者的輸入符合 tblUsers 表格中的第一條記錄,從而允許攻擊者以該用戶的名義登入網站。

SQL 指令植入式攻擊還有另一種形式,它發生在 ASP 服務器根據 querystring 參數動態生成網頁時。這里有一個例子,此 ASP 頁面從 URL 中提取出 querystring 參數中的 ID 值,然后根據 ID 值動態生成后繼頁面:  代碼:<% Dim p_lngID, objRS, strSQL p_lngID = Request("ID") strSQL = "SELECT * FROM tblArticles WHERE ID=" & p_lngID Set objRS = Server.CreateObject("ADODB.Recordset") objRS.Open strSQL, "DSN=..." If (Not objRS.EOF) Then Response.Write objRS("ArticleContent") Set objRS = Nothing %>

在一般情況下,此 ASP 腳本能夠顯示具有特定 ID 值的文章的內容,而 ID 值是由 URL 中的 querystring 參數指定的。例如:當URL為http://www.example.com/Article.asp?ID=1055 時,ASP 就會根據 ID 為 1055 的文章提供的內容生成頁面。

如同前述登錄頁面的例子一樣,此段代碼也向SQL 指令植入式攻擊敞開了大門。某些惡意用戶可能會把 querystring 中的文章 ID 值偷換為“0 or 1=1”等內容(也就是說,把 URL 換成http://www.example.com/Article.asp?ID=0 or 1=1) 從而誘使 ASP 腳本生成不安全的 SQL 指令如:  代碼:SELECT * FROM tblArticles WHERE ID=0 or 1=1

于是,數據庫將會返回所有文章的內容。

當然了,本例服務器所受的攻擊不一定會引起什么嚴重后果??墒?,攻擊者卻可能變本加厲,比如用同樣的手段發送 DELETE 等 SQL 指令。這只需要簡單地修改前述 URL 中的 querystring 參數就可以了!例如:任何人都可以通過 http://www.example.com/Article.asp?ID=1055; DELETE FROM tblArticles ” 之類的 URL 來訪問 Web 網站。

SQL 指令植入式攻擊的危害

SQL 指令植入式攻擊可能引起的危害取決于該網站的軟件環境和配置。當 Web 服務器以操作員(dbo)的身份訪問數據庫時,利用SQL 指令植入式攻擊就可能刪除所有表格、創建新表格,等等。當服務器以超級用戶 (sa) 的身份訪問數據庫時,利用SQL 指令植入式攻擊就可能控制整個 SQL 服務器;在某些配置下攻擊者甚至可以自行創建用戶帳號以完全操縱數據庫所在的 Windows 服務器。

杜絕SQL 指令植入式攻擊

杜絕SQL 指令植入式攻擊的第一步就是采用各種安全手段監控來自 ASP request 對象 (Request 、 Request.QueryString 、 Request.Form 、 Request.Cookies 和 Request.ServerVariables) 的用戶輸入,以確保 SQL 指令的可靠性。具體的安全手段根據你的 DBMS 而異,下面給出的都是基于 MS SQL Server的例子。

在前述登錄頁面的例子中,腳本期望得到的兩個輸入變量 (txtUserName 和 txtPassword)均為字符串類型。無論用戶在哪個參數中插入單引號,他都可能讓數據庫執行單引號中的 SQL 指令。為了杜絕此類SQL 指令植入式攻擊,我們可以借助 Replace 函數剔除單引號,比如:

代碼:p_strUsername = Replace(Request.Form("txtUsername"), "", "") p_strPassword = Replace(Request.Form("txtPassword"), "", "")

在第二個例子中,腳本期望的輸入變量是長整型變量 (ID) 。用戶可以通過在 ID 參數中插入特殊字符來運行不安全的 SQL 指令。為了為了杜絕此類SQL 指令植入式攻擊,我們只需要借助 CLng 函數限制 ID 值為長整型變量,比如:  代碼:p_lngID = CLng(Request("ID"))

當用戶試圖在 ID 中包含特殊字符時,CLng 就會產生一個錯誤。

為了進一步減少SQL 指令植入式攻擊的危脅,請務必清除客戶端錯誤信息文本中的所有技術資料。某些錯誤信息往往泄露了技術細節,從而讓攻擊者可以看出服務器的安全漏洞所在。這里指的錯誤信息不但包括應用程序生成的消息框,還包括來自 IIS 的出錯提示。為此,你可以禁止由 IIS 發送的詳細錯誤信息,而改用自定義的出錯頁面。(關于創建自定義的出錯頁面的更多信息,請務必參閱 《Creating Custom ASP Error Pages》。)

最后,為了減輕SQL 指令植入式攻擊的危害,請限制 Web 應用程序所用的數據庫訪問帳號權限。一般來說,應用程序沒有必要以 dbo 或者 sa 的身份訪問數據庫。記住,給它的權限越少,你的網站越安全!你還可以考慮分別給每個需要訪問數據庫的對象分配只擁有必需權限的帳號,以分散安全漏洞。例如:同是前端用戶界面,當用于公共場所時就比用于具有本地內容管理機制的平臺時更加需要嚴格限制數據庫訪問權限。

熱詞搜索:

上一篇:從IIS轉到SQL數據庫安全
下一篇:數據庫安全:當SQL Server數據庫崩潰時如何恢復

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
伊人夜夜躁av伊人久久| 欧美在线播放| 欧美成年视频| 久久久视频精品| 亚洲男女自偷自拍| 亚洲少妇中出一区| 亚洲人永久免费| 一本一道久久综合狠狠老精东影业| 久久蜜臀精品av| 影音先锋中文字幕一区| 欧美日韩国产另类不卡| 亚洲国产91| 欧美黄色免费| 亚洲一区二区免费看| 欧美日韩三级电影在线| 亚洲一区免费在线观看| 国产精品久久久久婷婷| 麻豆国产精品一区二区三区| a4yy欧美一区二区三区| 国产精品久久久久久模特| 另类亚洲自拍| 在线视频欧美精品| 国产一区二区三区四区老人| 欧美**字幕| 亚洲欧美高清| 亚洲精品一区二区三区四区高清| 国产综合第一页| 欧美大片在线看| 性感少妇一区| 一区二区三区四区五区视频 | 校园春色国产精品| 亚洲电影自拍| 国内成+人亚洲| 欧美日韩人人澡狠狠躁视频| 狼狼综合久久久久综合网| 欧美一区二区三区的| 亚洲天堂成人在线观看| 亚洲日本va午夜在线影院| 9久re热视频在线精品| 欧美一区高清| 欧美午夜一区二区| 亚洲三级影片| 欧美日韩高清免费| 亚洲欧洲在线播放| 久久久精品999| 欧美无砖砖区免费| 一区二区欧美精品| 国产乱码精品一区二区三| 亚洲视频成人| 国产欧美日韩综合| 久久国产欧美| 亚洲国产黄色| 免播放器亚洲| 亚洲精品美女在线| 欧美a级片网| 亚洲午夜精品网| 国产精品久久久久三级| 久久久久久久久久久一区 | 欧美国产综合视频| 91久久精品一区二区三区| 欧美精品亚洲| 欧美在线一二三区| 99视频日韩| 一区在线播放视频| 欧美日韩在线不卡| 欧美国产日韩亚洲一区| 一区二区欧美国产| 亚洲国产精品欧美一二99| 欧美人与性动交cc0o| 午夜视频久久久久久| 中国女人久久久| 亚洲精品欧洲| 国产视频一区在线| 欧美日韩国产综合视频在线观看 | 狠狠色狠狠色综合日日91app| 欧美成人高清视频| 欧美在线精品免播放器视频| 日韩视频―中文字幕| 亚洲精品久久久久久下一站| 国语自产精品视频在线看8查询8| 国产精品久久久久7777婷婷| 久久国产一区| 久久黄金**| 欧美一区影院| 久久午夜电影| 久久久久久穴| 久久精品一区中文字幕| 久热爱精品视频线路一| 欧美日韩精品在线播放| 久久一区亚洲| 久久夜色精品国产亚洲aⅴ| 久久亚洲综合色一区二区三区| 欧美专区18| 久久精品72免费观看| 欧美一级专区| 欧美成人免费在线观看| 欧美日韩国语| 国产精品视频精品视频| 国产亚洲成人一区| 最新国产拍偷乱拍精品| 99视频有精品| 久久久亚洲成人| 欧美另类一区| 国产亚洲成精品久久| 亚洲国产免费看| 国产欧美 在线欧美| 国产精品xxxxx| 国产一区二区三区视频在线观看| 黄页网站一区| 亚洲视频大全| 美女国内精品自产拍在线播放| 欧美视频1区| 亚洲日本免费电影| 亚洲影视综合| 欧美日韩免费观看中文| 好吊成人免视频| 亚洲在线观看视频| 欧美日韩国产精品自在自线| 狠狠狠色丁香婷婷综合激情| 亚洲专区免费| 欧美日韩国产经典色站一区二区三区| 国产欧美在线观看| 亚洲午夜精品17c| 免费亚洲电影在线| 亚洲大片免费看| 欧美激情国产日韩| 亚洲国产精品一区二区尤物区| 亚洲欧美制服中文字幕| 国产精品久久久久影院色老大| 最新精品在线| 欧美日韩一区成人| 亚洲激情一区| 欧美日韩免费一区二区三区视频| 亚洲精品日本| 欧美电影专区| 亚洲欧美日韩综合国产aⅴ| 国产欧美一区在线| 欧美在线播放高清精品| 国产精品网站在线播放| 久久九九电影| 中文有码久久| 国产午夜精品久久久久久免费视| 欧美一区二区三区四区高清| 黑人巨大精品欧美一区二区 | 欧美一区永久视频免费观看| 国产一区二区三区久久久| 篠田优中文在线播放第一区| 国产亚洲欧美一区在线观看 | 欧美xxx在线观看| 午夜在线不卡| 亚洲理伦在线| 国产一区二三区| 国产情人节一区| 免费欧美电影| 久久精品视频在线播放| 亚洲一二三四久久| 中文国产一区| 亚洲激情欧美激情| 国产精品一区三区| 国产精品久久久久久户外露出| 久久婷婷国产麻豆91天堂| 亚洲性线免费观看视频成熟| 黄色亚洲免费| 亚洲国产日韩欧美在线99| 激情自拍一区| 136国产福利精品导航| 欧美日韩国产成人在线免费| 久久精品人人做人人爽| 亚洲一区二区三区视频| 亚洲精品日韩精品| 国产精品99久久久久久久vr| 国产中文一区二区三区| 国产一区二区三区免费在线观看 | 国产精品日韩精品欧美精品| 欧美激情在线免费观看| 久久深夜福利免费观看| 久久综合五月天婷婷伊人| 久久激情五月丁香伊人| 狼人天天伊人久久| 欧美va天堂| 欧美三日本三级少妇三99| 国产精品红桃| 国产精品草莓在线免费观看| 欧美日韩国产精品| 欧美视频国产精品| 韩国福利一区| 一区二区在线视频观看| 亚洲国产日韩综合一区| 亚洲国产小视频在线观看| 亚洲日本中文字幕区| 亚洲一区二区三区在线看| 久久亚洲精品网站| 欧美精品久久一区| 国产一区二区看久久| 国产香蕉久久精品综合网| 日韩天堂av| 欧美插天视频在线播放| 欧美日韩亚洲国产精品| 国产精品永久入口久久久| 亚洲国产小视频|