色综合老司机第九色激情 _中文字幕日韩av资源站_国产+人+亚洲_久久久精品影院_久久久视频免费观看_欧美激情亚洲自拍_亚洲成av人片在线观看香蕉_热草久综合在线_欧美极品第一页_2020国产精品自拍

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > sql注入原理及4中常見(jiàn)注入攻擊代碼分析

sql注入原理及4中常見(jiàn)注入攻擊代碼分析

來(lái)源:千鋒教育
發(fā)布人:syq
時(shí)間: 2022-06-07 16:27:00 1654590420

  我們都知道,學(xué)安全,懂SQL注入是重中之重,因?yàn)榧词故乾F(xiàn)在SQL注入漏洞依然存在,只是相對(duì)于之前現(xiàn)在挖SQL注入變的困難了。而且知識(shí)點(diǎn)比較多,所以在這里總結(jié)一下。

  通過(guò)構(gòu)造有缺陷的代碼,來(lái)理解常見(jiàn)的幾種SQL注入。本文只是講解幾種注入原理,沒(méi)有詳細(xì)的利用過(guò)程。

  sql注入原理

  1.SQL注入漏洞的產(chǎn)生需要滿足兩個(gè)條件:

  2.參數(shù)用戶(hù)可控:前端傳給后端的參數(shù)內(nèi)容是用戶(hù)可以控制的。

  參數(shù)帶入數(shù)據(jù)庫(kù)查詢(xún):傳入的參數(shù)拼接到SQL語(yǔ)句并帶入數(shù)據(jù)庫(kù)查詢(xún)。所以在實(shí)際環(huán)境中開(kāi)發(fā)者要秉持“外部參數(shù)皆不可信原則”進(jìn)行開(kāi)發(fā)。

  4種常見(jiàn)的sql注入攻擊

  1、union注入攻擊

  先看代碼

<?php

$con=mysqli_connect("localhost","root","XFAICL1314","dvwa"); #連接數(shù)據(jù)庫(kù),我這里直接連接了dvwa的數(shù)據(jù)庫(kù)
if(mysqli_connect_error())
{
    echo "連接失敗:" .mysqli_connect_error();
}
$id=$_GET['id'];
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
echo $row['user'] . ":" . $row['password'];
echo "<br>";

  在union注入頁(yè)面中,程序獲取GET參數(shù)id,對(duì)用戶(hù)傳過(guò)來(lái)的id值沒(méi)有進(jìn)行過(guò)濾,直接拼接到SQL語(yǔ)句中,在數(shù)據(jù)庫(kù)中查詢(xún)id對(duì)應(yīng)的內(nèi)容,并將這一條查詢(xún)結(jié)果中的user和password 輸出到頁(yè)面。進(jìn)行union注入攻擊前提是頁(yè)面有回顯。然后就是注入的常規(guī)思路,判斷類(lèi)型,判斷字段數(shù),使用union查詢(xún)相關(guān)數(shù)據(jù)。

  2、布爾盲注攻擊

  先看代碼  

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if(mysqli_connect_error())
{
    echo "連接失敗:" .mysqli_connect_error();
}
$id=$_GET['id'];
if(preg_match("/union|sleep|benchmark/i",$id)){
    exit("on");
}
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
if ($row) {
    exit("yes");
}
else{
    exit("no");
}
?>

  在布爾盲注頁(yè)面中,程序先獲取GET參數(shù)id,通過(guò)preg_match()函數(shù)判斷其中是否存在union sleep benchmark等危險(xiǎn)字符。然后將參數(shù)id拼接到SQL語(yǔ)句,從數(shù)據(jù)庫(kù)查詢(xún),如果有結(jié)果,返回yes,否則返回no。

  所以訪問(wèn)這個(gè)頁(yè)面,代碼根據(jù)查詢(xún)結(jié)果返回只返回yes和no,不返回?cái)?shù)據(jù)庫(kù)中的任何結(jié)果,所以上一種的union注入在這里行不通。

  嘗試?yán)貌紶柮ぷⅰ2紶柮ぷ⑹侵笜?gòu)造SQL判斷語(yǔ)句,通過(guò)查看頁(yè)面的返回結(jié)果來(lái)推測(cè)哪些SQL判斷是成立的。例如,我們可以判斷數(shù)據(jù)庫(kù)名的長(zhǎng)度構(gòu)造語(yǔ)句如下。and length(database())>=1 #依次增加,查看返回結(jié)果。

sql注入原理及4中常見(jiàn)注入攻擊代碼分析1736

sql注入原理及4中常見(jiàn)注入攻擊代碼分析1481

 

  通過(guò)上面的語(yǔ)句我們可以猜到數(shù)據(jù)庫(kù)名長(zhǎng)度為4。

  接著使用逐字符判斷的方式獲取數(shù)據(jù)庫(kù)庫(kù)名,數(shù)據(jù)庫(kù)庫(kù)名范圍一般都是az,字母09。構(gòu)造語(yǔ)句如下:

  and substr(database(),1,1)=要猜解的字母(轉(zhuǎn)換成16進(jìn)制)

  substr是截取的意思,構(gòu)造語(yǔ)句的含義是,截取database()的值,從第一個(gè)開(kāi)始,每次返回一個(gè)。這里要注意,要和limit語(yǔ)句區(qū)分開(kāi),limit從0開(kāi)始排序,substr從1開(kāi)始排序。因?yàn)槲抑罃?shù)據(jù)庫(kù)的第一個(gè)字母是d,所以直接換成d,轉(zhuǎn)換成16進(jìn)制就是0x64。結(jié)果如下: 

sql注入原理及4中常見(jiàn)注入攻擊代碼分析1736 

  在真實(shí)環(huán)境中,自己手工的話,工作量有點(diǎn)大,可以借助burp的爆破功能爆破要猜解的字母。

  同樣,也可以利用substr()來(lái)猜解表名和字段。構(gòu)造語(yǔ)句:

  and substr((select table_name from information_schema.tables where table_schema=庫(kù)名 limit 0,1),1,1)=要猜解的字母(這里指表名)

0

  用這樣的方法,可以猜解出所有的表名和字段,手工會(huì)累死,可以借助burp或者sqlmap。

  3、報(bào)錯(cuò)注入攻擊

  先看代碼 

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if (mysqli_connect_error())
{
    echo "連接失敗:".mysqli_connect_error();
}
$id=$_GET['id'];
if($result=mysqli_query($con,"select *from users where `user_id`=".$id))
{
    echo "ok";
}else{
    echo mysqli_error($con);
}
?>

  查看代碼,在報(bào)錯(cuò)注入頁(yè)面中,程序獲取GET參數(shù)id后,將id拼接到SQL語(yǔ)句中查詢(xún),如果執(zhí)行成功,就輸出ok,如果出錯(cuò),就通過(guò)echo mysqli_error($con)將錯(cuò)誤信息輸出到頁(yè)面。我們可以利用這種錯(cuò)誤回顯,通過(guò)updatexml()、floor()等函數(shù)將我們要查詢(xún)的內(nèi)容顯示到頁(yè)面上。

  例如,我們通過(guò)updatexml()獲取user()的值,構(gòu)造如下語(yǔ)句:

  and updatexml(1,concat(0x7e,(select user()),0x7e),1) #0x7e是~16進(jìn)制編碼

  發(fā)現(xiàn)查詢(xún)出了user()的值

sql注入原理及4中常見(jiàn)注入攻擊代碼分析2545

  同樣,我們也可以查詢(xún)出database()的值

  and updatexml(1,concat(0x7e,(select database()),0x7e),1) #0x7e是~16進(jìn)制編碼

  查詢(xún)出了數(shù)據(jù)庫(kù)名

sql注入原理及4中常見(jiàn)注入攻擊代碼分析2651

  我們可以用這種方法查詢(xún)出剩下的所有表名和字段,只需要構(gòu)造相關(guān)的SQL語(yǔ)句就可以了。

  4、時(shí)間盲注入攻擊

  先看代碼 

<?php
$con=mysqli_connect("localhost","root","XFAICL1314","dvwa");
if (mysqli_connect_error())
{
    echo "連接失敗:".mysqli_error();
}
$id=$_GET['id'];
if (preg_match("/union/i",$id)){
    exit("<html><body>no</body></html>");
}
$result=mysqli_query($con,"select * from users where `user_id`=".$id);
$row=mysqli_fetch_array($result);
if ($row){
    exit("<html><body>yes</body></html>");
}
else{
    exit("<html><body>no</body></html>");
}
?>

  查看代碼,在時(shí)間盲注頁(yè)面中,程序獲取GET參數(shù)id,通過(guò)preg_match()函數(shù)判斷是否存在union危險(xiǎn)字符,然后將id拼接到SQL語(yǔ)句中,并帶入數(shù)據(jù)庫(kù)查詢(xún)。如果有結(jié)果返回yes,沒(méi)有結(jié)果返回no。不返回?cái)?shù)據(jù)庫(kù)中的任何數(shù)據(jù)。

  它與布爾盲注的不同在于,時(shí)間盲注是利用sleep()或benchmark()等函數(shù)讓執(zhí)行時(shí)間變長(zhǎng)。一般和if(expr1,expr2,expr3)結(jié)合使用,這里的if語(yǔ)句的含義為如果expr1為真,則if()返回expr2,否則返回expr3。所以判斷數(shù)據(jù)庫(kù)的長(zhǎng)度,咱們構(gòu)造的語(yǔ)句如下:

  if (length(database())>3,sleep(5),1) #判斷數(shù)據(jù)庫(kù)長(zhǎng)度,如果大于3,休眠5秒,否則查詢(xún)1 

sql注入原理及4中常見(jiàn)注入攻擊代碼分析3475

sql注入原理及4中常見(jiàn)注入攻擊代碼分析3473

  由上面圖片,我們通過(guò)時(shí)間可以判斷出,數(shù)據(jù)庫(kù)的長(zhǎng)度為4。

  得到長(zhǎng)度后,通過(guò)substr()來(lái)查詢(xún)數(shù)據(jù)庫(kù)的第一個(gè)字母,這里和布爾盲注很類(lèi)似,構(gòu)造如下語(yǔ)句:

  and if (substr(database(),1,1)=庫(kù)的第一個(gè)字母,sleep(5),1)

sql注入原理及4中常見(jiàn)注入攻擊代碼分析3605

  依次進(jìn)行猜解。依次類(lèi)推,可以猜解出數(shù)據(jù)庫(kù)完整的庫(kù)名,表名,字段名和具體數(shù)據(jù)。手工的話依舊是一個(gè)浩大的工程,一般借助工具。

  總結(jié)

  本文對(duì)union注入、布爾盲注、報(bào)錯(cuò)注入、時(shí)間盲注的原理和代碼進(jìn)行了簡(jiǎn)單的分析。

  更多關(guān)于網(wǎng)絡(luò)安全的問(wèn)題,歡迎咨詢(xún)千鋒教育在線名師。千鋒教育多年辦學(xué),課程大綱緊跟企業(yè)需求,更科學(xué)更嚴(yán)謹(jǐn),每年培養(yǎng)泛IT人才近2萬(wàn)人。不論你是零基礎(chǔ)還是想提升,都可以找到適合的班型,千鋒教育隨時(shí)歡迎你來(lái)試聽(tīng)。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專(zhuān)屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
抖音小店怎么做代銷(xiāo)

抖音已經(jīng)成為了一個(gè)非常受歡迎的短視頻應(yīng)用程序,在其中許多用戶(hù)都精心打造了自己的小店,用于銷(xiāo)售各種各樣的商品,獲取額外的收入。然而,要想...詳情>>

2023-10-08 15:28:41
怎樣開(kāi)抖音小店帶貨賺錢(qián)

隨著直播帶貨的火熱,越來(lái)越多的人開(kāi)始嘗試通過(guò)抖音小店來(lái)開(kāi)展帶貨業(yè)務(wù)。抖音小店是抖音直播帶貨的配套,可以讓用戶(hù)在購(gòu)買(mǎi)直播中產(chǎn)品時(shí)就實(shí)現(xiàn)購(gòu)...詳情>>

2023-10-08 15:06:36
能不能幫我打開(kāi)抖音小店店鋪呢怎么弄

抖音小店是近年來(lái)非常火爆的一個(gè)網(wǎng)絡(luò)業(yè)務(wù),也是提供了很多商業(yè)機(jī)會(huì)的平臺(tái)。對(duì)于一個(gè)創(chuàng)業(yè)者而言,開(kāi)設(shè)抖音小店是一個(gè)不錯(cuò)的選擇。但是,許多小店...詳情>>

2023-10-08 15:01:21
藍(lán)v抖音小店怎么開(kāi)通店鋪

藍(lán)v抖音小店是一個(gè)非常熱門(mén)的電商平臺(tái),它可以讓賣(mài)家在抖音上開(kāi)設(shè)自己的店鋪,從而出售自己的商品。隨著抖音的不斷發(fā)展壯大,越來(lái)越多的賣(mài)家希...詳情>>

2023-10-08 14:51:53
抖音小店怎么更改類(lèi)目名稱(chēng)

抖音小店是現(xiàn)在非常火熱的一種網(wǎng)店形態(tài),許多小生意也從中獲得了收益。但是隨著經(jīng)營(yíng)時(shí)間的增長(zhǎng),小店也需要對(duì)自己的類(lèi)目名稱(chēng)進(jìn)行更改,因?yàn)檫@可...詳情>>

2023-10-08 14:46:50
快速通道
色综合老司机第九色激情 _中文字幕日韩av资源站_国产+人+亚洲_久久久精品影院_久久久视频免费观看_欧美激情亚洲自拍_亚洲成av人片在线观看香蕉_热草久综合在线_欧美极品第一页_2020国产精品自拍
色网站国产精品| 99国产精品国产精品毛片| 一区二区三区日本| 99久久99久久精品免费看蜜桃| 欧美zozozo| 国产精品一级黄| 国产性天天综合网| 成人a级免费电影| 亚洲精品国产a久久久久久| 欧美性淫爽ww久久久久无| 亚洲国产欧美在线人成| 日韩一二在线观看| 高清av一区二区| 亚洲精品国产第一综合99久久 | 欧美日韩高清在线播放| 人人狠狠综合久久亚洲| 久久嫩草精品久久久精品一| 91在线看国产| 日本vs亚洲vs韩国一区三区 | 欧美日韩国产在线播放网站| 奇米精品一区二区三区在线观看| 精品久久久久久久久久久院品网| 成人黄色小视频| 日日夜夜免费精品视频| 国产精品美女视频| 日韩一区二区三区免费看 | 欧美一区二区福利在线| 国产成人无遮挡在线视频| 一二三区精品福利视频| 精品99久久久久久| 日本久久一区二区| 国产超碰在线一区| 激情五月激情综合网| 亚洲一区二区三区自拍| 国产精品乱码妇女bbbb| 精品久久久久久久久久久久久久久久久| 99精品久久久久久| 国产一二精品视频| 麻豆国产一区二区| 日韩精品视频网| 亚洲美女精品一区| 亚洲精品第一国产综合野| 国产无一区二区| 26uuu欧美| 日韩久久精品一区| 日韩欧美精品三级| 精品久久国产老人久久综合| 欧美一区二区三区人| 在线91免费看| 91精品婷婷国产综合久久| 欧美日韩不卡一区| 欧美日韩国产色站一区二区三区| 91色在线porny| 99re这里都是精品| 91天堂素人约啪| 欧美在线你懂得| 欧美日韩国产一级| 91精品国产色综合久久| 欧美一区二区免费| 亚洲精品一区二区三区99| 久久久久久夜精品精品免费| 久久九九久精品国产免费直播| 国产三级一区二区| 亚洲欧美成人一区二区三区| 一区二区理论电影在线观看| 一区二区三区日韩| 日本美女一区二区| 国产乱码精品一区二区三区五月婷| 国产福利91精品| 91原创在线视频| 欧美群妇大交群的观看方式| 日韩精品在线一区| 亚洲欧美综合色| 天堂精品中文字幕在线| 国产一区在线观看麻豆| 色老汉一区二区三区| 欧美大片一区二区三区| 国产精品亲子伦对白| 日本aⅴ精品一区二区三区| 岛国精品在线观看| 欧美精品 国产精品| 国产精品久久久久久久裸模| 丝袜美腿亚洲色图| 97se狠狠狠综合亚洲狠狠| 欧美精品久久99| 亚洲私人黄色宅男| 国内外精品视频| 欧美精品一二三| 亚洲欧美电影一区二区| 国产一区二区久久| 日韩视频一区二区| 夜夜夜精品看看| 91在线视频观看| 久久精品人人做人人爽人人| 日韩国产欧美在线观看| 91久久人澡人人添人人爽欧美| 国产午夜精品久久久久久久| 秋霞电影网一区二区| 欧美色手机在线观看| 综合久久久久久| 波多野结衣91| 中文字幕第一区综合| 国产美女久久久久| 欧美一区二区三区视频在线观看| 亚洲在线视频免费观看| 91在线精品一区二区| 成人免费在线播放视频| fc2成人免费人成在线观看播放| 精品捆绑美女sm三区| 卡一卡二国产精品| 2021久久国产精品不只是精品| 日本91福利区| 精品国产一区二区三区不卡| 日韩电影在线观看网站| 欧美久久婷婷综合色| 免费观看成人av| 欧美成人a在线| 国产精品中文欧美| 久久欧美一区二区| 成人自拍视频在线观看| 中文av字幕一区| 99精品久久只有精品| 亚洲国产va精品久久久不卡综合| 在线播放一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 国产精品三级在线观看| 99国产精品一区| 免费日韩伦理电影| 欧美精品一区二区三区蜜桃视频| 国产成人综合网站| 国产精品免费视频网站| 欧美私人免费视频| 久久成人久久爱| 亚洲欧美在线视频观看| 欧美午夜电影在线播放| 久久66热偷产精品| 亚洲欧美国产三级| 日韩精品一区二区三区在线观看| 国产99久久久国产精品潘金| 亚洲综合一区在线| 久久精品一区八戒影视| 在线亚洲一区二区| 卡一卡二国产精品| 亚洲国产美女搞黄色| 久久精品在线观看| 欧美一区二区三区在线视频| 97se亚洲国产综合在线| 国产真实乱子伦精品视频| 亚洲色图一区二区三区| 久久夜色精品国产噜噜av| 欧美日韩亚州综合| 国产成人免费9x9x人网站视频| 亚洲一区二区在线观看视频 | 亚洲精品伦理在线| 精品电影一区二区三区| 欧美三级一区二区| 成人高清免费观看| 国产麻豆视频一区二区| 首页亚洲欧美制服丝腿| 亚洲一区在线观看免费| 国产精品热久久久久夜色精品三区| 日韩欧美国产一区二区三区| 欧美日韩免费不卡视频一区二区三区| 成人黄色在线视频| www.欧美精品一二区| 国产成人在线电影| 成人性生交大片免费看中文网站| 国产一区二区主播在线| 久久国产夜色精品鲁鲁99| 美腿丝袜亚洲三区| 激情五月激情综合网| 国内精品视频一区二区三区八戒| 麻豆精品久久精品色综合| 免费成人美女在线观看| 久久国产生活片100| 精品一区二区免费看| 美女视频一区在线观看| 老司机精品视频一区二区三区| 免费久久精品视频| 久久成人精品无人区| 国产精品中文字幕日韩精品 | 国产亚洲一区二区三区在线观看 | 亚洲国产另类av| 亚洲国产一区二区三区 | 精品国产污污免费网站入口 | 99久久夜色精品国产网站| 国产91在线|亚洲| 成人av在线电影| 91麻豆精品在线观看| 欧美日韩你懂的| 欧美精品一区二区蜜臀亚洲| 中文字幕乱码一区二区免费| 国产精品久久久久久福利一牛影视 | 国产一区二区视频在线| 国产成人在线影院| 91福利国产精品| 精品国精品国产尤物美女| 综合激情成人伊人| 欧美aaaaaa午夜精品| 成人久久18免费网站麻豆 |