亚洲 国产精品 日韩-亚洲 激情-亚洲 欧美 91-亚洲 欧美 成人日韩-青青青草视频在线观看-青青青草影院

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > sql注入原理及4中常見注入攻擊代碼分析

sql注入原理及4中常見注入攻擊代碼分析

來源:千鋒教育
發布人:syq
時間: 2022-06-07 16:27:00 1654590420

  我們都知道,學安全,懂SQL注入是重中之重,因為即使是現在SQL注入漏洞依然存在,只是相對于之前現在挖SQL注入變的困難了。而且知識點比較多,所以在這里總結一下。

  通過構造有缺陷的代碼,來理解常見的幾種SQL注入。本文只是講解幾種注入原理,沒有詳細的利用過程。

  sql注入原理

  1.SQL注入漏洞的產生需要滿足兩個條件:

  2.參數用戶可控:前端傳給后端的參數內容是用戶可以控制的。

  參數帶入數據庫查詢:傳入的參數拼接到SQL語句并帶入數據庫查詢。所以在實際環境中開發者要秉持“外部參數皆不可信原則”進行開發。

  4種常見的sql注入攻擊

  1、union注入攻擊

  先看代碼

<?php

$con=mysqli_connect("localhost","root","XFAICL1314","dvwa"); #連接數據庫,我這里直接連接了dvwa的數據庫
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注入頁面中,程序獲取GET參數id,對用戶傳過來的id值沒有進行過濾,直接拼接到SQL語句中,在數據庫中查詢id對應的內容,并將這一條查詢結果中的user和password 輸出到頁面。進行union注入攻擊前提是頁面有回顯。然后就是注入的常規思路,判斷類型,判斷字段數,使用union查詢相關數據。

  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");
}
?>

  在布爾盲注頁面中,程序先獲取GET參數id,通過preg_match()函數判斷其中是否存在union sleep benchmark等危險字符。然后將參數id拼接到SQL語句,從數據庫查詢,如果有結果,返回yes,否則返回no。

  所以訪問這個頁面,代碼根據查詢結果返回只返回yes和no,不返回數據庫中的任何結果,所以上一種的union注入在這里行不通。

  嘗試利用布爾盲注。布爾盲注是指構造SQL判斷語句,通過查看頁面的返回結果來推測哪些SQL判斷是成立的。例如,我們可以判斷數據庫名的長度構造語句如下。and length(database())>=1 #依次增加,查看返回結果。

sql注入原理及4中常見注入攻擊代碼分析1736

sql注入原理及4中常見注入攻擊代碼分析1481

 

  通過上面的語句我們可以猜到數據庫名長度為4。

  接著使用逐字符判斷的方式獲取數據庫庫名,數據庫庫名范圍一般都是az,字母09。構造語句如下:

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

  substr是截取的意思,構造語句的含義是,截取database()的值,從第一個開始,每次返回一個。這里要注意,要和limit語句區分開,limit從0開始排序,substr從1開始排序。因為我知道數據庫的第一個字母是d,所以直接換成d,轉換成16進制就是0x64。結果如下: 

sql注入原理及4中常見注入攻擊代碼分析1736 

  在真實環境中,自己手工的話,工作量有點大,可以借助burp的爆破功能爆破要猜解的字母。

  同樣,也可以利用substr()來猜解表名和字段。構造語句:

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

0

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

  3、報錯注入攻擊

  先看代碼 

<?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);
}
?>

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

  例如,我們通過updatexml()獲取user()的值,構造如下語句:

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

  發現查詢出了user()的值

sql注入原理及4中常見注入攻擊代碼分析2545

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

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

  查詢出了數據庫名

sql注入原理及4中常見注入攻擊代碼分析2651

  我們可以用這種方法查詢出剩下的所有表名和字段,只需要構造相關的SQL語句就可以了。

  4、時間盲注入攻擊

  先看代碼 

<?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>");
}
?>

  查看代碼,在時間盲注頁面中,程序獲取GET參數id,通過preg_match()函數判斷是否存在union危險字符,然后將id拼接到SQL語句中,并帶入數據庫查詢。如果有結果返回yes,沒有結果返回no。不返回數據庫中的任何數據。

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

  if (length(database())>3,sleep(5),1) #判斷數據庫長度,如果大于3,休眠5秒,否則查詢1 

sql注入原理及4中常見注入攻擊代碼分析3475

sql注入原理及4中常見注入攻擊代碼分析3473

  由上面圖片,我們通過時間可以判斷出,數據庫的長度為4。

  得到長度后,通過substr()來查詢數據庫的第一個字母,這里和布爾盲注很類似,構造如下語句:

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

sql注入原理及4中常見注入攻擊代碼分析3605

  依次進行猜解。依次類推,可以猜解出數據庫完整的庫名,表名,字段名和具體數據。手工的話依舊是一個浩大的工程,一般借助工具。

  總結

  本文對union注入、布爾盲注、報錯注入、時間盲注的原理和代碼進行了簡單的分析。

  更多關于網絡安全的問題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學,課程大綱緊跟企業需求,更科學更嚴謹,每年培養泛IT人才近2萬人。不論你是零基礎還是想提升,都可以找到適合的班型,千鋒教育隨時歡迎你來試聽。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
CHINA浴室洗澡VOYEUR| 伊人久久精品久久亚洲一区| 亚洲中文字幕无码一区| 97人人超碰国产精品最新o| 车子一晃一晃的就C进去了肉| 国产精品久久国产精品99盘| 精品久久亚洲中文字幕| 欧美XXXXX牲另类人与| 熟女俱乐部五十路六十路AV| 亚洲国产成人综合精品| 2021国内精品久久久久精免费| 成人免费A级毛片无码片2022| 国产无套内射又大又猛又粗又爽| 久久久久久久女国产乱让韩| 日本插槽X8插槽怎么用| 亚洲AV无码成人精品区明星换面 | 日本熟妇人妻XXXXX人电影 | 国产偷V国产偷V亚洲高清| 看国产黄大片在线观看| 色综合久久精品亚洲国产消防| 亚洲国产精品日韩AV专区| 99视频69E精品视频| 国产乱子夫妻XX黑人XYX真爽 | 在线天堂免费观看.WWW| 成人片黄网站色大片免费观看| 国语对白做受XXXXX在线| 欧美成人WWW免费全部网站| 午夜131美女爱做视频| 久久亚洲精品成人AV无码涩涩屋| 欧美一区二区三区成人片在线| 我和公发生了性关系公| 无码人妻久久一区二区三区蜜桃 | 美国ZOOM动物| 天天做天天爱夜夜夜爽毛片 | 丰满亚洲大尺度无码无码专线| 久久精品免费观看国产| 少妇高潮抽搐无码久久AV| 一碰就有水的女人男人喜欢?| 粗大的内捧猛烈进出无码| 久久精品国产亚洲AV麻豆网站 | 国产精品无码V在线观看| 免费无码又爽又刺激高潮的动态图 | 黑人巨根在线观看| 全部孕妇毛片丰满孕妇孕交| 亚洲成AV不卡无码无码不卡 | 又硬又大又长又粗又深| 国产精品国语对白露脸在线播放| 男生坤坤放在女生坤坤叫什么| 性一交一乱一伦一色一情| おまえの母亲をだます怎么读| 精品久久久99大香线蕉| 上课我穿超短裙被同桌摸出水| 伊人久久大香线蕉综合AV| 国产清纯美女爆白浆视频| 人妻内射一区二区在线视频| 亚洲一码和欧洲二码的尺码区别 | 年轻漂亮的人妻被公侵犯BD免费| 亚洲AV乱码中文一区二区三区 | А√天堂资源8在线官网地址 | 偷拍 亚洲 欧洲 综合| 99精产国品一二三产区MBA| 精品国产三级A∨在线| 天堂资源在线WWW在线观看| AV天堂亚洲国产AV| 久久精品伊人一区二区三区| 无遮挡边吃奶边做的视频刺激| YY111111少妇无码影院| 麻豆精品传媒一二三区| 亚洲AV无码专区在线电影成人| 丰满熟女一区二区三区蜜桃臀 | 久久久久人妻一区精品色| 午夜成人鲁丝片午夜精品| 成年午夜免费韩国做受| 男人吃奶摸下挵进去好爽| 亚洲色大18成人网站WWW在线| 337P粉嫩胞人体高清视频免费| 好男人2019在线视频播放观看| 少妇爆乳无码AV无码专区| A∨变态另类天堂无码专区| 久久久久久老熟妇人妻av| 亚洲AV色香蕉一区二区蜜桃| 国产AⅤ无码专区亚洲AV| 人妻出差精油按摩被中出| 中英字幕乱码在线观看| 久久久WWW成人免费精品| 亚洲AAAAA特级| 国产极品视觉盛宴专区| 色婷婷AV一区二区三区在线观看 | 欧洲站高端8码特大码47| 中文在线っと好きだっ最新版 | 天干天干天啪啪夜爽爽AV| 超碰97人人做人人爱可以下载 | 午夜理论片YY6080影院| 丰满岳乱妇三级高清| 日韩国产女人久久久| XXXX性BBBB欧美| 欧美黑人巨大最猛性XXXXX| 在厨房被C到高潮A毛片奶水| 久久九九有精品国产23百花影院| 亚洲国产AV一区二区三区四区| 国产乱人伦偷精品视频色欲| 天天在线看无码AV片| 第九午夜不卡影院| 日韩熟妇无码字幕视频毛片| 被喂春药蹂躏的欲仙欲死视频| 欧美XXXX做受欧美GAY| 337P大胆啪啪私拍人体| 男女啪啪免费观看的网址| 中国老熟女XXXⅩ全部| 理论片午午伦夜理片影院| 伊人久久大香线蕉AV一区| 久久久亚洲欧洲日产无码AV| 亚洲无人区码二码三码区别| 精品一区二区三区免费毛片爱| 亚洲精品成人H在线观看| 精品久久久BBBB人妻| 亚洲色偷无码一区二区蜜桃AV| 激情综合亚洲色婷婷五月| 亚洲精品国产成人99久久6| 精品成品国色天香卡一卡三| 亚洲成a人蜜臀AV在线播放| 狠狠躁夜夜躁人人爽天天不卡软件| 亚洲AV无码专区青青草原| 激情内射人妻1区2区3区| 亚洲男女一区二区三区| 久久久久99精品国产片| 又色又爽的无遮挡免费网址| 末发育娇小性色XXXX| BBW大屁股肥臀妇女ASS| 人妻丰满熟妇无码区免费| 粗大黑人巨精大战欧美成人| 他趴在两腿中间舔我私密有事吗| 国产精品久久国产三级国不卡顿| 小SAO货水好多真紧H视频| 黑人大战欲求不满人妻| 亚洲啪啪AV无码片| 麻豆网神马久久人鬼片| CHINESE0LDMAN老汉| 日韩成人精品久久网站| 国产精品国产高清国产AV| 午夜人妻理论片天堂影院| 精品久久久久久久久中文字幕| 淫淫网站日本网站黑人大吊| 男女啪啪进出阳道猛进| 成人乱子视频在线播放| 天天澡天天揉揉AV无码| 极品婬荡少妇XXXX欧美| 与子敌伦刺激对白播放| 热RE99久久6国产精品免费| 公交车后车座的疯狂的做| 小13箩利洗澡无码免费视频| 久久不见久久见免费影院国语| 主人调教下贱的烂货| 日产精品一卡2卡三卡4乱码| 国产精品久久久久久精品电影| 亚洲国产精品成人精品无码区在线 | 成在人线AV无码免费高潮水老板| 五十路熟妇无码专区| 久久久久黑人强伦姧人妻| AV无码精品久久久久精品免费| 色偷偷色噜噜狠狠网站久久| 国产香蕉97碰碰视频VA碰碰看| 野花日本大全免费观看版动漫| 欧美饥渴熟妇高潮喷水水| 工口全彩H肉无遮挡无翼乌| 亚洲VA中文慕无码久久AV| 蜜臂无码AV在线| 丰满多毛的陰户视频| 亚洲国产精品第一区二区| 女警察受呻吟双腿大开H| 国产AV无码专区亚洲AV麻豆 | 久久久久久亚洲AV无码蜜芽| ZOZOTOWN| 亚洲AV无码国产精品色午| 麻豆一二三区AV精品传媒 | 9999国产精品欧美久久久久久| 色综合久久久久综合一本到桃花网 | 人妻少妇-嫩草影院| 国产又粗老女人又硬又爽| 永久免费观看午夜成人网站| 肉欲扒灰合集100篇| 精品人妻暴躁一区二区三区| BGMBGMBGM老太太HD| 性色a∨精品高清在线观看| 免费下载破解看片APP的软件| 国产GAYSEXCHINA男同| 一本色道无码道在线观看 | 欧美丰满熟妇XXXX| 国产成人无码AⅤ| 私人影院播放器大全| 久久99精品国产麻豆| 波多野结衣AV一区二区全免费观看| 亚洲AV无码成H人在线观看| 男人猛躁进女人免费播放| 国产精品看高国产精品不卡| 中国在线观看免费高清完整版| 首页 动漫 亚洲 欧美 日韩| 林静公交车被做到高C的原因| 国产刺激男女视频在线| 中文字幕精品一二三四五六七八|