MySQL長字符截?cái)嗟膶?shí)現(xiàn)示例
MySQL超長字符截?cái)嘤置?quot;SQL-Column-Truncation",是安全研究者Stefan Esser在2008 年8月提出的。
在MySQL中的一個(gè)設(shè)置里有一個(gè)sql_mode選項(xiàng),當(dāng)sql_mode設(shè)置為default時(shí),即沒有開啟STRICT_ALL_TABLES選項(xiàng)時(shí)(MySQLsql_mode默認(rèn)即default),MySQL對(duì)插入超長的值只會(huì)提示warning,而不是error,這樣就可能會(huì)導(dǎo)致一些截?cái)鄦栴}。
新建一張表測(cè)試,表結(jié)構(gòu)如下(MySQL5.1):
CREATE TABLE USERS( id int(11) NOT NULL, //長度為7 username varchar(7)NOT NULL, password varchar(12)NOT NULL , )
分別插入以下SQL語句(注入提示消息)。
①插入正常的SQL語句。
mysql> insert into users(id,username,password)values(1,'admin','admin');//成功插入,無警告,無錯(cuò)誤 Query OK,1 row affected(0.00 sec)
②插入錯(cuò)誤的SQL語句,此時(shí)的"admin "右面有三個(gè)空格,長度為8,已經(jīng)超過了原有的規(guī)定長度。
mysql> insert into users(id,username,password)values(2,'admin ','admin'); //成功插入,一個(gè)警告 Query OK,1 row affected,1 warning(0.00 sec)
③插入錯(cuò)誤的SQL語句,長度已經(jīng)超過原有的規(guī)定長度。
mysql> insert into users(id,username,password) values(3,'admin x','admin'); //成功插入,一個(gè)警告 Query OK,1 row affected,1 warning(0.00 sec)
MySQL提示三條語句都已經(jīng)插入到數(shù)據(jù)庫,只不過后面兩條語句產(chǎn)生了警告。那么最終有沒有插入到數(shù)據(jù)庫呢?執(zhí)行SQL語句查看一下就知道了。
mysql> select username from users;
可以看到,三條數(shù)據(jù)都被插入到數(shù)據(jù)庫,但值發(fā)生了變化,此時(shí)在通過length來取得長度,判斷值的長度。
mysql> select length(username)from users where id =1 ;
可以發(fā)現(xiàn),第二條與第三條數(shù)據(jù)的長度為7,也就是列的規(guī)定長度,由此可知,在默認(rèn)情況下,如果數(shù)據(jù)超出列默認(rèn)長度,MySQL會(huì)將其截?cái)唷?/p>
但這樣何來攻擊一說呢?
面查詢用戶名為'admin'的用戶就知道了。
mysql> select username from users where username='admin';
只查詢用戶名為admin的用戶,但是另外兩個(gè)長度不一致的admin用戶也被查詢出,這樣就會(huì)造成一些安全問題,比如,有一處管理員登錄是這樣判斷的,語句如下:
$sql = "select count(*) from users where username='admin' and password='*******;
假設(shè)這條SQL語句沒有任何注入漏洞,攻擊者也可能登錄到管理頁面。假設(shè)管理員登錄的用戶名為 admin,那么攻擊者僅需要注冊(cè)一個(gè)"admin”用戶即可輕易進(jìn)入后臺(tái)管理頁面,像著名的WordPress就被這樣的方式攻擊過。
到此這篇關(guān)于MySQL長字符截?cái)嗟膶?shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)MySQL長字符截?cái)鄡?nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mysql 強(qiáng)大的trim() 函數(shù)
這篇文章主要介紹了mysql 強(qiáng)大的trim() 函數(shù)使用方法,需要的朋友可以參考下2014-03-03
MySQL系列理解運(yùn)用union(all)與limit及exists關(guān)鍵字教程
這篇文章主要為大家介紹了MySQL系列中union(all)、limit及exists關(guān)鍵字的教程示例講解,通過本篇文章就可以理解MySQL中的這些關(guān)鍵字的概念以及實(shí)際的運(yùn)用2021-10-10
配置Mysql主從服務(wù)實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了配置Mysql主從服務(wù)實(shí)現(xiàn)實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-05-05
Mysql通過ibd文件恢復(fù)數(shù)據(jù)的詳細(xì)步驟
mysql在使用的過程中,難免遇到數(shù)據(jù)庫表誤操作,下面這篇文章主要給大家介紹了關(guān)于Mysql通過ibd文件恢復(fù)數(shù)據(jù)的詳細(xì)步驟,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
Ubuntu10下如何搭建MySQL Proxy讀寫分離探討
MySQL Proxy是一個(gè)處于你的Client端和MySQL server端之間的簡單程序,它可以監(jiān)測(cè)、分析或改變它們的通信2012-11-11

