CG-CTF SQL註入

来源:https://www.cnblogs.com/Timesi/archive/2019/07/26/11249845.html
-Advertisement-
Play Games

SQL註入1 題目 訪問題目網址 先查看一下源碼 仔細分析一下核心源碼 通過分析源碼知道了 的值為 ,因為sql查詢語句里有and,必須and前後同時成立才可以查詢,但是現在不知道 對應的值,所以考慮能不能不判斷pass,直接判斷user,於是想到是不是可以將user判斷語句閉合併註釋後面的內容,這 ...


SQL註入1

題目

訪問題目網址

先查看一下源碼

仔細分析一下核心源碼

<?php
if($_POST[user] && $_POST[pass]) {      //判斷user和pass兩個變數不為空
mysql_connect(SAE_MYSQL_HOST_M . ':' . SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS);        //連接資料庫
  mysql_select_db(SAE_MYSQL_DB);    //選擇要使用的庫
  $user = trim($_POST[user]);       //去除輸入的user變數兩側的空白字元
  $pass = md5(trim($_POST[pass]));  //去除pass變數兩側空白字元再進行md5加密
  $sql="select user from ctf where (user='".$user."') and (pw='".$pass."')";    //根據輸入的user和pass構造查詢語句
    echo '</br>'.$sql;  //回顯查找語句
  $query = mysql_fetch_array(mysql_query($sql));    //使用構造的查詢語句查詢資料庫並返回結果集
  if($query[user]=="admin") {
      echo "<p>Logged in! flag:******************** </p>";
  }
  if($query[user] != "admin") {
    echo("<p>You are not admin!</p>");
  }         //判斷結果集中的user參數對應的值是不是admin,如果是返回flag,不是則返回 You are not admin!
}
echo $query[user];      //回顯查詢到的user值
?>

通過分析源碼知道了user的值為admin,因為sql查詢語句里有and,必須and前後同時成立才可以查詢,但是現在不知道pass對應的值,所以考慮能不能不判斷pass,直接判斷user,於是想到是不是可以將user判斷語句閉合併註釋後面的內容,這樣就不會對pass進行判斷,pass就直接輸入111,於是構造下麵的語句。

這樣的話查詢語句就變成了

select user from ctf where (user='admin') #') and (pw='111')

嘗試提交看看會不會返回flag。

成功拿到flag


補充:Mysql的註釋語句有三種

1./* */
註釋一段內容,這裡明顯不適用。

2.--
註釋-- 後的語句直到行尾,註意這裡的--後面要有一個空格,但是題目中使用了trim()函數去除空格,所以也不適用。

3.#
註釋#後的語句直到行尾。

SQL註入2

題目

訪問題目網址

還是先查看一下源碼

分析核心源碼

<?php
if($_POST[user] && $_POST[pass]) {
   mysql_connect(SAE_MYSQL_HOST_M . ':' . SAE_MYSQL_PORT,SAE_MYSQL_USER,SAE_MYSQL_PASS);
  mysql_select_db(SAE_MYSQL_DB);
  $user = $_POST[user];
  $pass = md5($_POST[pass]);
  $query = @mysql_fetch_array(mysql_query("select pw from ctf where user='$user'"));
  if (($query[pw]) && (!strcasecmp($pass, $query[pw]))) {
      echo "<p>Logged in! Key: ntcf{**************} </p>";
  }
  else {
    echo("<p>Log in failure!</p>");
  }
}
?>

找到最關鍵的語句

if (($query[pw]) && (!strcasecmp($pass, $query[pw]))) {
      echo "<p>Logged in! Key: ntcf{**************} </p>";
  }
  else {
    echo("<p>Log in failure!</p>");
  }

解題思路:

1.可以看到這裡只對密碼進行了對比,沒有進行user的對比,所以應該考慮怎麼使得$query[pw]存在且strcasecmp($pass, $query[pw]))為假。

2.$query[pw]是MySQL查詢結果集中的值,只要MySQL語句返回值即可存在。
要使strcasecmp($pass, $query[pw])為假,就要使得$pass的值小於等於$query[pw](比較ASCII碼)。$pass是我們輸入值的md5值,$query[pw]是資料庫中的正確密碼。因為$pass是md5值,32位,而$query[pw]不知道,所以看看能不能將$query[pw]的值構造成我們需要的32位,且大於$pass的值,根據題目的提示,考察union聯合查詢,嘗試構造如下語句:

select pw from ctf where user=''union select md5(2)#'

這個語句的輸出因為閉合了user,user為空,查不到任何值,而後面select md5(2),則會返回2的md5值,所以返回的結果會變成下麵這樣:

+----------------------------------+
| pw                               |
+----------------------------------+
| c81e728d9d4c2f636f067f89cc14862c |
+----------------------------------+

這樣從$query[pw]查詢到的值就會變成2的md5值,這時我密碼輸入2,這樣經過strcasecmp()函數的對比會返回0,達到目的。


成功拿到flag


補充:
1.strcasecmp(str1,str2)函數

strcasecmp(str1,str2)函數返回的結果是比較兩個字元串的ASCII碼,從第一位開始,相等就比較下一位,如果比較過程中,一旦出現str1的某一個字元的ASCII碼和str2的不等,那麼將返回這兩個字元的ASCII碼值之差。

2.union聯合查詢
當使用union聯合查詢時,前一個select查詢的列名將會作為輸出結果的列名,後一個select只會返回查詢列的內容,而沒有列名。

union前後查詢列名一致

mysql> select * from t2;
+----+-------+
| id | score |
+----+-------+
|  1 |    33 |
+----+-------+
1 row in set (0.00 sec)

mysql> select * from t5;
+-----------+---------+------+
| user      | pw      | id   |
+-----------+---------+------+
| admin     | 000000  | NULL |
| admin2    | 1000000 | NULL |
| gubeiqing | gu      |   10 |
+-----------+---------+------+
3 rows in set (0.00 sec)

mysql> select id from t2 union select id from t5;
+------+
| id   |
+------+
|    1 |
| NULL |
|   10 |
+------+
3 rows in set (0.00 sec)

union前後查詢列名不一致

mysql> select * from t2;
+----+-------+
| id | score |
+----+-------+
|  1 |    33 |
+----+-------+
1 row in set (0.00 sec)

mysql> select * from t5;
+-----------+---------+------+
| user      | pw      | id   |
+-----------+---------+------+
| admin     | 000000  | NULL |
| admin2    | 1000000 | NULL |
| gubeiqing | gu      |   10 |
+-----------+---------+------+
3 rows in set (0.00 sec)

mysql> select id from t2 union select pw from t5;
+---------+
| id      |
+---------+
| 1       |
| 000000  |
| 1000000 |
| gu      |
+---------+
4 rows in set (0.00 sec)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MySQL索引原理 什麼是索引? “索引”是為了能夠更快地查詢數據。比如一本書的目錄,就是這本書的內容的索引,讀者可以通過在目錄中快速查找自己想要的內容,然後根據頁碼去找到具體的章節。 資料庫也是一樣,如果查詢語句使用到了索引,會先去索引裡面查詢,取得數據所在行的物理地址,進而訪問數據。 索引的優缺 ...
  • Flink Standalone 集群 HA 配置 1. HA 集群環境規劃 使用三台節點實現兩主兩從集群(由於筆記本性能限制,不能開啟太多虛擬機,其實使用三 台和四台機器在安裝配置上沒有本質區別) Jobmanager:hadoop100hadoop101【一個 active,一個 standby ...
  • 資料庫存儲引擎是資料庫底層軟體組件,資料庫管理系統使用數據引擎進行創建、查詢、更新和刪除數據操作。不同的存儲引擎提供不同的存儲機制、索引技巧、鎖定水平等功能,使用不同的存儲引擎還可以獲得特定的功能。 現在許多資料庫管理系統都支持多種不同的存儲引擎。MySQL 的核心就是存儲引擎。 如創建一個Inno ...
  • superset功能概述: 豐富的數據可視化集 易於使用的界面,用於探索和可視化數據 創建和共用儀錶板 與主要身份驗證提供程式集成的企業級身份驗證(通過Flask AppBuilder進行資料庫,OpenID,LDAP,OAuth和REMOTE_USER) 可擴展的高粒度安全/許可權模型,允許誰可以訪 ...
  • 最近做數據同步功能,從介面獲取數據然後存到資料庫中以便後續對數據進行相關操作,下麵就貼一下相關代碼。 從介面拿到數據後,下麵就將數據存到資料庫中: 其中AUTOID_SEQ.NEXTVAL為Oracle中的自增序列 至此,數據已經同步到指定的資料庫中啦,打完收工! 註意:拼接sql的時候一定要按照字 ...
  • 對於信息安全有要求的,在數據下發和同步過程中需要對含有用戶身份信息的敏感欄位脫敏,包括用戶姓名、證件號、地址等等,下麵是自定義函數的代碼CREATE OR REPLACE FUNCTION F_GET_SENSITIVE(IN_STR VARCHAR, IN_TYPE NUMBER) RETURN ... ...
  • 還原資料庫的時候明明選擇了備份集,還是提示未選擇還原的備份集 後來查了下,是因為我本地有兩個資料庫(2008R2和2014),對應的兩個資料庫實例。而還原bak是sqlserver2014的備份,我預設登的是2008的實例,所以一直有問題。 怎麼查看資料庫的實例名:https://zhinan.so ...
  • EOMONTH()查詢日期數據所屬月數的最後一天; YEAR(COL)輸出日期數據的年份、month(col)輸出日期數據的月份; 查詢數據時in與exist的區別:in是先查詢條件,然後只查詢一次條件。而exists是先運行select語句,查詢出所有的數據以後在運行條件語句,多次查詢,查詢的次數 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...