0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

如何針對(duì)Mysql漏洞測(cè)試您自己的Web服務(wù)器

454398 ? 來源:wv ? 2019-09-26 15:31 ? 次閱讀

第1步:設(shè)置測(cè)試環(huán)境

要測(cè)試代碼,您應(yīng)該設(shè)置一個(gè)測(cè)試環(huán)境。可以在計(jì)算機(jī)上使用xampp或lampp完成此操作。當(dāng)然,您可以自己用php設(shè)置一個(gè)Apache網(wǎng)絡(luò)服務(wù)器。

您將需要一個(gè)網(wǎng)絡(luò)服務(wù)器,一個(gè)mysql數(shù)據(jù)庫和一個(gè)運(yùn)行中的php解釋器來執(zhí)行代碼。

步驟2:示例數(shù)據(jù)庫

對(duì)于我們的測(cè)試案例,我們使用一個(gè)非?;镜臄?shù)據(jù)庫,其中有兩個(gè)用戶。使用md5算法保護(hù)密碼。只需在數(shù)據(jù)庫上運(yùn)行以下mysql代碼即可創(chuàng)建表:

SET SQL_MODE = “NO_AUTO_VALUE_ON_ZERO”;

SET AUTOCOMMIT = 0;

START TRANSACTION;

SET time_zone = “+00:00”;

CREATE TABLE IF NOT EXISTS `user` (

`id` bigint(15) NOT NULL,

`email` varchar(255) NOT NULL,

`password` varchar(32) NOT NULL

) ENGINE=InnoDB DEFAULT CHARSET=latin1 AUTO_INCREMENT=3 ;

INSERT INTO `user` (`id`, `email`, `password`) VALUES

(1, ‘admin@mysite.com’, ‘b655e3f4ae881514c4896b9cd707e4d2’),

(2, ‘guest@mysite.com’, ‘5d41402abc4b2a76b9719d911017c592’);

ALTER TABLE `user`

ADD PRIMARY KEY (`id`);

ALTER TABLE `user`

MODIFY `id` bigint(15) NOT NULL AUTO_INCREMENT,AUTO_INCREMENT=3;COMMIT;

步驟3:關(guān)于密碼安全性的簡(jiǎn)短介紹

全世界的計(jì)算能力正在飛速增長(zhǎng),md5不再是強(qiáng)大的哈希算法。所使用的哈希是使用以下密碼生成的:

b655e3f4ae881514c4896b9cd707e4d2 = top secret password that will never be cracked that fast

5d41402abc4b2a76b9719d911017c592 = hello

由于存在彩虹表之類的東西,即使google本身也是一個(gè)很好的密碼破解機(jī)。當(dāng)您搜索“ 5d41402abc4b2a76b9719d911017c592”時(shí),第一個(gè)結(jié)果是明文密碼。當(dāng)您在Google中搜索“ b655e3f4ae881514c4896b9cd707e4d2”時(shí),由于輸入字符串太長(zhǎng)而無法使用蠻力方法破解,因此您將不會(huì)獲得任何結(jié)果。

因此:請(qǐng)使用在任何詞典中都不會(huì)出現(xiàn)的長(zhǎng)密碼!/p》

步驟4:示例代碼

如何針對(duì)Mysql漏洞測(cè)試您自己的Web服務(wù)器

出于測(cè)試原因,我編寫了這個(gè)小腳本。它打開一個(gè)數(shù)據(jù)庫連接,提供一個(gè)表單,并嘗試在數(shù)據(jù)庫中查找與您輸入的憑據(jù)(電子郵件和密碼)匹配的用戶。只需將腳本保存在Web服務(wù)器上,然后將文件命名為“ mysql-injection.php”即可。當(dāng)數(shù)據(jù)庫名稱不同時(shí),可能必須為“ mysql_select_db”函數(shù)更新數(shù)據(jù)庫名稱:

error_reporting(E_ALL ^ E_DEPRECATED);

mysql_connect(‘localhost’, ‘root’, ‘’);

mysql_select_db(‘mysql-injection’);

if (!empty($_POST[‘email’]) && !empty($_POST[‘password’]))

{

$query = ‘SELECT * FROM `user` WHERE `email` = \’‘.$_POST[’email‘]?!痋‘ AND `password` = \’‘.md5($_POST[’password‘])?!痋‘’;

echo ‘Used query: ’,$query,‘’;

$resource = mysql_query($query);

$matches = mysql_num_rows($resource);

if ($matches 》 0)

{

$user = mysql_fetch_assoc($resource);

echo ‘Hello ’.$user[‘email’]?!?!’;

}

else

{

echo ‘Invalid credentials!’;

}

}

?》

Log in to get privileges!

Mail:

Password:

步驟5:測(cè)試腳本

要開始使用,只需在Web瀏覽器上調(diào)用腳本即可。在我的情況下,該網(wǎng)址為http://sand.box:8081/mysql-injection.php,因?yàn)槲覍ⅰ?sand.box”路由為“ 127.0.0.1”。您只需調(diào)用http://sand.box:8081/mysql-injection.php或http://sand.box:8081/mysql-injection.php即可使其正常工作。

我們現(xiàn)在可以使用以下憑據(jù)測(cè)試登錄:

admin@mysite.com:top secret password that will never be cracked that fast

guest@mysite.com:hello

如您在屏幕快照中所見,腳本返回“ Hello ”以證明您的登錄憑據(jù)正確。使用任何其他組合可獲得“無效的憑據(jù)!”錯(cuò)誤。

這是有效的用戶身份驗(yàn)證。但是它非常危險(xiǎn)。請(qǐng)查看下一步,了解原因。

步驟6:幕后花絮

由于腳本輸出了用于選擇正確用戶的數(shù)據(jù)庫查詢,因此您可以看到背后發(fā)生了什么現(xiàn)場(chǎng)。當(dāng)您以管理員身份登錄時(shí),以下查詢:

‘SELECT * FROM `user` WHERE `email` = \’‘.$_POST[’email‘]?!痋‘ AND `password` = \’‘.md5($_POST[’password‘])。’\‘’

計(jì)算為:

‘SELECT * FROM `user` WHERE `email` = \’admin@mysite.com\‘ AND `password` = \’‘.md5(’top secret password that will never be cracked that fast‘)。’\‘’

,然后計(jì)算為:

‘SELECT * FROM `user` WHERE `email` = \’admin@mysite.com\‘ AND `password` = \’b655e3f4ae881514c4896b9cd707e4d2\‘’

,發(fā)送到mysql數(shù)據(jù)庫的是:

SELECT * FROM `user` WHERE `email` = ‘a(chǎn)dmin@mysite.com’ AND `password` = ‘b655e3f4ae881514c4896b9cd707e4d2’

因此,只需通過電子郵件地址和密碼選擇一個(gè)用戶。在這種情況下,這是對(duì)郵件驗(yàn)證的可靠期望。變量$ _POST [‘email’]在附加到查詢之前是不安全的,因此我們可以在此處注入很多邪惡的東西。 $ _POST [‘password’]變量在被隱式存儲(chǔ)到數(shù)據(jù)庫查詢之前被傳遞給md5(),因此這是“意外的安全”,因?yàn)閙d5()僅返回?cái)?shù)字和字符,沒有任何東西會(huì)使我們的查詢崩潰。 》

步驟7:破解!

正如我們?cè)谏弦徊街辛私獾降哪菢樱? _ POST [‘email’]是我們的后門。因此,當(dāng)您輸入以下電子郵件時(shí),您可以以所需的任何用戶身份登錄。對(duì)于ID為1的用戶:

test@test.de‘ OR `id` = 1 OR 1 = ’

對(duì)于ID為2的用戶:

test@test.de‘ OR `id` = 2 OR 1 = ’

如您所見,使用的mysql查詢?nèi)缦拢?/p>

SELECT * FROM `user` WHERE `email` = ‘test@test.de’ OR `id` = 1 OR 1 = ‘’ AND `password` = ‘098f6bcd4621d373cade4e832627b4f6’

由于查詢中沒有括號(hào),因此我們可以通過在電子郵件中傳遞一個(gè)‘來停止字符串。之后,我們可以修改查詢本身。因此,我們僅添加另一個(gè)與用戶ID相關(guān)的“ OR”條件。這使電子郵件和密碼已過時(shí),因?yàn)橐坏?OR”條件為真,mysql就會(huì)停止檢查條件。因此,如果我們的數(shù)據(jù)庫中有一個(gè)ID為“ 1”的用戶,我們便已登錄。

步驟8:保護(hù)您的代碼

要確保此代碼安全,只需轉(zhuǎn)義用戶輸入即可。例如,可以使用mysql_real_escape_string方法來完成此操作。另一個(gè)功能可能是斜杠。因此,“安全”解決方案將使用:

mysql_real_escape_string($_POST[’email‘])

而不是

$_POST[’email‘]

所以這是最終的php代碼:

$query = ’SELECT * FROM `user` WHERE `email` = \‘’.mysql_real_escape_string($_POST[‘email’])。‘\’ AND `password` = \‘’.md5($_POST[‘password’])。‘\’‘;

計(jì)算的查詢?yōu)椋?/p>

SELECT * FROM `user` WHERE `email` = ’test@test.de\‘ OR `id` = 1 OR 1 = \’‘ AND `password` = ’098f6bcd4621d373cade4e832627b4f6‘

因此,您可以看到,字符串中的單引號(hào)現(xiàn)在已轉(zhuǎn)義,不再結(jié)束mysql字符串。這將導(dǎo)致查詢搜索以下電子郵件地址:

test@test.de\’ OR `id` = 1 OR 1 = \‘

當(dāng)然,這將失敗,因?yàn)閿?shù)據(jù)庫中沒有匹配的電子郵件。

第9步:僅僅為了獲得一個(gè)想法

編寫此指令是為了在一個(gè)非?;镜那闆r下獲得mysql注入的想法。在2015年,您不會(huì)自己編寫php應(yīng)用程序,而是使用可以為您處理大部分安全性和數(shù)據(jù)庫內(nèi)容的框架和庫。但是您應(yīng)該知道在幕后發(fā)生了什么事,以便快速,安全地編寫代碼。

例如,一個(gè)好的解決方案是使用symfony2框架。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • Web服務(wù)器
    +關(guān)注

    關(guān)注

    0

    文章

    138

    瀏覽量

    24435
  • 漏洞
    +關(guān)注

    關(guān)注

    0

    文章

    204

    瀏覽量

    15396
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    服務(wù)器 Flexus X 實(shí)例,鏡像切換與服務(wù)器壓力測(cè)試

    服務(wù)器 Flexus X 壓力測(cè)試 1、購(gòu)買華為云 Flexus X 實(shí)例 Flexus云服務(wù)器X實(shí)例-華為云 (huaweicloud.com) ? 2、xshell 遠(yuǎn)程連接服務(wù)器
    的頭像 發(fā)表于 01-03 09:23 ?112次閱讀
    云<b class='flag-5'>服務(wù)器</b> Flexus X 實(shí)例,鏡像切換與<b class='flag-5'>服務(wù)器</b>壓力<b class='flag-5'>測(cè)試</b>

    華為云 Flexus X 實(shí)例 MySQL 性能加速評(píng)測(cè)及對(duì)比

    X 實(shí)例加速 MySQL 測(cè)試 7 3.1 sysbench 簡(jiǎn)介 8 3.2?Flexus 云服務(wù)器 X 實(shí)例安裝 sysbench8 3.3?Flexus X 加速 MySQL
    的頭像 發(fā)表于 12-25 17:10 ?185次閱讀
    華為云 Flexus X 實(shí)例 <b class='flag-5'>MySQL</b> 性能加速評(píng)測(cè)及對(duì)比

    服務(wù)器 Flexus X 實(shí)例 MySQL 應(yīng)用加速測(cè)試

    文章目錄 目錄 文章目錄 ? 購(gòu)買配置 ? 基本配置參考如下: ? 連接服務(wù)器 ? 查詢MySQL狀態(tài) ? 啟動(dòng)MySQL ? 添加配置 ? 添加密碼并修改權(quán)限 ? 性能測(cè)試 ? C#
    的頭像 發(fā)表于 12-24 12:19 ?175次閱讀
    云<b class='flag-5'>服務(wù)器</b> Flexus X 實(shí)例 <b class='flag-5'>MySQL</b> 應(yīng)用加速<b class='flag-5'>測(cè)試</b>

    香港云服務(wù)器怎么部署MySQL數(shù)據(jù)庫?

    在香港云服務(wù)器上部署MySQL數(shù)據(jù)庫的步驟如下: 步驟 1: 更新軟件包列表 首先,確保軟件包列表是最新的。在終端中執(zhí)行以下命令: sudo apt update 步驟 2: 安裝 MySQL
    的頭像 發(fā)表于 11-14 16:15 ?189次閱讀

    GPU服務(wù)器和傳統(tǒng)的服務(wù)器有什么區(qū)別

    GPU服務(wù)器與傳統(tǒng)的服務(wù)器在多個(gè)方面存在顯著差異,主機(jī)推薦小編為整理發(fā)布GPU服務(wù)器和傳統(tǒng)的服務(wù)器有什么區(qū)別,以下是對(duì)這些差異的詳細(xì)分析。
    的頭像 發(fā)表于 11-07 11:05 ?221次閱讀

    如何測(cè)試SMTP服務(wù)器功能

    在開始測(cè)試SMTP服務(wù)器功能之前,了解其重要性是關(guān)鍵。SMTP服務(wù)器是電子郵件系統(tǒng)的核心,負(fù)責(zé)郵件的發(fā)送和接收。如果SMTP服務(wù)器出現(xiàn)問題,可能會(huì)導(dǎo)致郵件延遲、丟失或無法發(fā)送,影響企業(yè)
    的頭像 發(fā)表于 10-30 17:31 ?809次閱讀

    新加坡服務(wù)器的速度測(cè)試方法有哪些

    輸入ping加上服務(wù)器的IP地址或域名,然后觀察返回的結(jié)果,包括延遲和丟包情況。較低的響應(yīng)時(shí)間表示較快的訪問速度。 Traceroute測(cè)試: Traceroute命令用于追蹤數(shù)據(jù)包從的設(shè)備到
    的頭像 發(fā)表于 10-14 14:55 ?174次閱讀

    使用NS1串口服務(wù)器HTTP模式上傳服務(wù)器數(shù)據(jù)

    HTTP協(xié)議工作于客戶端-服務(wù)端架構(gòu)之上。瀏覽作為HTTP客戶端通過URL向HTTP服務(wù)端即Web服務(wù)器發(fā)送所有請(qǐng)求。
    的頭像 發(fā)表于 08-30 12:36 ?386次閱讀
    使用NS1串口<b class='flag-5'>服務(wù)器</b>HTTP模式上傳<b class='flag-5'>服務(wù)器</b>數(shù)據(jù)

    常見的服務(wù)器容器和漏洞類型匯總

    常見的服務(wù)器容器包括KubeSphere、Tomcat、Nginx、Apache等,它們?cè)谔峁┍憬莸?b class='flag-5'>服務(wù)部署和靈活的網(wǎng)絡(luò)功能的同時(shí),也可能存在著一定的安全風(fēng)險(xiǎn)。這些容器的漏洞可能導(dǎo)致數(shù)據(jù)泄露、權(quán)限被非授權(quán)訪問甚至系統(tǒng)被完全控制。
    的頭像 發(fā)表于 08-29 10:39 ?248次閱讀

    如何在阿里ECS服務(wù)器上架設(shè)自己的OpenVPN服務(wù)器?

    需要自己架設(shè)服務(wù)器,讓現(xiàn)場(chǎng)的IR615路由連接自己服務(wù)器。能通過自己
    發(fā)表于 07-25 06:14

    如何使用espconn api實(shí)現(xiàn)一個(gè)Web服務(wù)器?

    我正在嘗試使用 espconn api 實(shí)現(xiàn)一個(gè) Web 服務(wù)器。 在一些請(qǐng)求之后,我收到將此錯(cuò)誤(err1,超過最大時(shí)間值)寫入 uart,下一個(gè)espconn_send導(dǎo)致致命異常 (28)。 沒有關(guān)于此的文檔... 我該如何解決這個(gè)問題?
    發(fā)表于 07-18 07:46

    服務(wù)測(cè)試web測(cè)試嗎為什么

    服務(wù)測(cè)試Web測(cè)試是兩個(gè)不同的概念,但它們?cè)谲浖_發(fā)和測(cè)試過程中是相互關(guān)聯(lián)的。本文將詳細(xì)解釋這兩個(gè)概念以及它們之間的關(guān)系。
    的頭像 發(fā)表于 05-30 15:30 ?636次閱讀

    接口測(cè)試怎么測(cè)多個(gè)服務(wù)器連接

    接口測(cè)試是軟件開發(fā)過程中的一個(gè)重要環(huán)節(jié),用于驗(yàn)證系統(tǒng)組件之間的交互是否符合預(yù)期。在多服務(wù)器環(huán)境中,接口測(cè)試的復(fù)雜性會(huì)增加,因?yàn)樾枰紤]服務(wù)器之間的連接和通信。本文將詳細(xì)介紹如何在多
    的頭像 發(fā)表于 05-30 15:16 ?435次閱讀

    服務(wù)器的特點(diǎn)

    服務(wù)器是一種基于云計(jì)算技術(shù)的服務(wù)器服務(wù),它提供了可靈活擴(kuò)展的計(jì)算資源和環(huán)境。Rak部落小編為整理發(fā)布云服務(wù)器的特點(diǎn),希望對(duì)您有幫助。
    的頭像 發(fā)表于 04-09 09:30 ?446次閱讀

    服務(wù)器是干什么的

     云服務(wù)器是干什么的?很多小白用戶會(huì)有疑惑,今天小編為整理云服務(wù)器是干什么的相關(guān)資料,希望對(duì)了解云服務(wù)器是干什么的有幫助。
    的頭像 發(fā)表于 02-18 09:58 ?1503次閱讀