fileinclude-宜兴网信办解题思路--呕心沥血--非常详细!

news2024/10/6 5:58:56

7711781928779a46b19a7117f3698798.jpeg

第一步-分析题目:

打开题目场景,如下图:

bec26e61adf0ef46852876aaeba4209a.png

 这上面显示说,flag在这个/var/www/html/flag.php文件中。由此可知,这道题是文件包含题。

明确了目标,咱们在场景那个页面按下F12来看下源代码。

7fb0199e1af6ff3b3cc52de221b1093e.png

在做题之前咱们先了解了解COOKIE,可以把COOKIE理解为我们打开一个网站,我们属于客户端,打开一个网站就相当于我们给网站服务器发送了一个请求,然后服务器记录用户状态,颁发了一个COOKIE,然后我们更改这个COOKIE的值,再次请求。

下面直接看源代码中最重要的部分。

$lan = $_COOKIE['language'];

 这行代码说明COOKIE是可控的,$lan 由COOKIE传入;language后面的值才是COOKIE值,是我们要传入$lan 里面的内容;所以说我们把这个值给language才可以发送请求。

if(!$lan)

{

@setcookie("language","english");

@include("english.php");

}

!是反之的意思可以理解为不的意思,如果说咱们上传的COOKIE 不存在$lan,则这就说明我们的$lan包含在english.php文件中。

else

{

@include($lan.".php");

}

 else反之如果说我们上传的COOKIE存在$lan,则$lan会自动拼接.php,并进行包含。

分析到这里就可以了。

第二步-工具:

用到的有Kali,burpsuite,火狐浏览器。

第三步-起飞:

先打开火狐进入到场景:

d77b760a6fa2cded32bb645661edf756.png

随后打开burpsuite并进入Proxy:

626c4690535637360f798e9159633ce2.png

 去火狐刷新一下场景:

b6a0a0bf21eb93491faeb6565ef27485.png

第二行send to repeater送去重放:

488fdfc4c940539a0561591831ac99c8.png

进入repeater重放功能:

fd9d4e258b379f85a38cc81554e132f0.png

接下来我们该构造 payload数据包了,在构造之前我们先了解了解php filter伪协议的规则,后面会用到。

php filter伪协议的规则:

php://filter/过滤器|过滤器/resource=待过滤的数据流

知道了规则后, 那我们就来构造payload数据包:

php://filter/convert.base64-encode/resource=/var/www/html/flag

read读取,convert转换,base64,encode编码,

 resource=flag转换到flag中,就是说把flag.php文件转换为base64编码格式。

/var/www/html/flag意思是flag.php文件在var文件夹里面的www文件夹里面的html文件夹里面,可以看这篇博客最上面的第一张图片。

 因为$lan会自动拼接.php,并进行包含,所以我们不需要加.php后缀。

上传payload数据包: 

dbf1a2c1b6f32f80a825a646ea4e89a9.png

 点Send发送请求,拿到base64编码:

bf06500c5251b0413d2ccfb69c9dc01e.png

进行base64编码解码,拿到flag:

f935a08aab3979aa51f730f09e1455cb.png

6eef7efdff21a023146af24a3378d13b.png

 补充:

 base64编码解码工具网上可以搜到的,是免费的。

最后如果想要了解更多,请关注我CSDN:m0_73734159

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/513046.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JetBrains Fleet-下一代idea安装教程

最近了解到了Fleet——宣称是下一代idea的开发工具,接下来介绍这个工具怎么安装。 JetBrains: Essential tools for software developers and teamsJetBrains is a cutting-edge software vendor specializing in the creation of intelligent development tools, …

基于多动作深度强化学习的柔性车间调度研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

JS_函数注释实现调用提示

/** * 函数名称* author 小歪 <123qq.com>* license Apache-2.0* param {Function} func func是函数类型参数* param {number} [duration] 使用[]描述可选值* param {object} options 配置对象options* param {string} options.url 请求地址* param {GET|POST} options.m…

shell脚本工具

shell脚本常用的工具 sortuniqtrcut sort sort是一个以行为单位对文件内容排序的工具&#xff0c;也可以根据不同的数据类型来排序&#xff0c;例如数据和字符的排序就不一样。比较原则是从首字符向后&#xff0c;依次按ASCII码进行比较&#xff0c;最后将他们升序输出 语法格…

Android Studio Flamingo新版本Logcat使用介绍

Android Studio更新后Logcat日志样式大变样了&#xff0c;和之前版本差距很大 下面就介绍下新版本的Logcat&#xff1a; 一、切换设备 可以选择切换当前打印日志的设备 二、日志过滤 和之前版本最大的区别就是这个日志过滤了 1、按包名过滤 //打印当前运行包的日志 packag…

Oracle21c下载与安装教程

Oracle21c数据库下载与安装教程 1. 下载安装包2. 解压3. 点击执行setp.exe4. 选择“创建并配置单实例数据库”&#xff0c;点击下一步5. 选择"桌面类(D)"&#xff0c;点击下一步6. 使用“虚拟账户”&#xff0c;点击下一步7. 典型安装&#xff0c;输入Oracle基目录&a…

fork+父子进程在理解+进程控制

索引 fork父子进程在理解进程控制1.进程终止2.进程等待3.获取进程状态Status fork父子进程在理解 fork之后&#xff0c;内核做了什么&#xff1f; 将分配新的内存块和内核数据结构给子进程将父进程部分数据结构拷贝至子进程添加子进程到系统列表中fork返回开始调度器调度 fo…

【人工智能】VScode中使用ChatGPT之Bito插件

文章目录 前言一、到官网下载VScode软件二、VScode软件安装步骤三、Bito插件下载与VScode软件中的使用四、注册Bito 前言 之前在VScode中使用ChatGPT中文版&#xff0c;后来要注册与收费&#xff0c;可采用一些ChatGPT中文版的替代插件。 后发现BitoAI插件功能同样强大&#…

SpringMVC框架详解

1.MVC概念 MVC 模式代表 Model-View-Controller&#xff08;模型-视图-控制器&#xff09; 模式。这种模式用于应用程序的分层开发。 Model&#xff08;模型&#xff09; - 模型代表一个存取数据的对象或 JAVA POJO&#xff0c;工程中的JavaBean。 View&#xff08;视图&…

阿里云服务器建站教程(5分钟网站上线)

使用阿里云服务器快速搭建网站教程&#xff0c;先为云服务器安装宝塔面板&#xff0c;然后在宝塔面板上新建站点&#xff0c;阿里云服务器网以搭建WordPress网站博客为例&#xff0c;来详细说下从阿里云服务器CPU内存配置选择、Web环境、域名解析到网站上线全流程&#xff1a; …

JAVA学习和题目

先上每日一题看看 1015. 可被 K 整除的最小整数 难度中等147收藏分享切换为英文接收动态反馈 给定正整数 k &#xff0c;你需要找出可以被 k 整除的、仅包含数字 1 的最 小 正整数 n 的长度。 返回 n 的长度。如果不存在这样的 n &#xff0c;就返回-1。 注意&#xff1a;…

async_simple编译测试(一)

前言 async_simple 阿里开源的轻量级 C 异步框架 提供了基于 C20 无栈协程(Lazy)、有栈协程(Uthread) 以及 Future/Promise 等异步组件&#xff0c;能够轻松完成 C 异步的开发&#xff0c;广泛应用于阿里的图计算引擎、时序数据库、搜索引擎等系统。 1&#xff1a;准备 下载地…

Microsoft Edge使用方法和心得

Microsoft Edge 使用方法和心得 本文目录&#xff1a; 一、写在前面的话 二、Edge浏览器简介 三、Microsoft Edge性能 3.1、睡眠标签 3.2、启动加速 3.3、清晰度提升 四、Microsoft Edge游戏特性 五、高效工作 5.1、标签页组 5.2、垂直标签 5.3、集锦 5.4、边栏 5…

Google I/O 2023 - Dart 3 发布,快来看看有什么更新吧

核心原文链接&#xff1a; https://medium.com/dartlang/announcing-dart-3-53f065a10635 自从 Flutter Forword 发布了 Dart 3α 预览 之后&#xff0c;大家对 Dart 3 的正式发布就一直翘首以待&#xff0c;这不仅仅是 Dart 版本号追上了 Flutter 版本号&#xff0c;更是 Dart…

【数据结构】- 教你一步完美应对面试官让你10分钟内实现带头双向循环链表(下)

文章目录 前言&#x1f31f;一、面试官让你十分钟内实现带头双向循环链表&#x1f31f;二、对链表的清晰认知&#x1f31f;三、根据上述步骤简单实现&#x1f30f;3.1结构:&#x1f30f;3.2查找(LTFind)LTEraseLTInsert&#xff1a;&#x1f30f;3.3头插&#xff1a;&#x1f4…

为什么要做计划跟踪:没有计划,就没有控制

日常工作中&#xff0c;我们每天都被大量的信息和任务填满&#xff0c;常常由于任务繁冗复杂&#xff0c;让人陷入一种无所适从的状态。 我们经常会看到很多如何安排工作计划的教程&#xff0c;比如&#xff1a; 要把大的项目分解为小目标&#xff0c;小目目标再分解为日常任务…

【技术干货】PCB焊盘设计之问题详解

SMT的组装质量与PCB焊盘设计有直接的关系&#xff0c;焊盘的大小比例十分重要。如果PCB焊盘设计正确&#xff0c;贴装时少量的歪斜可以再次回流焊纠正(称为自定位或自校正效应)&#xff0c;相反&#xff0c;如果PCB焊盘设计不正确&#xff0c;即使贴装位置十分准确&#xff0c;…

十分钟教你搭建类似ChatGPT的安卓应用程序

大家好&#xff0c;我是易安&#xff01; Chat GPT 是当今著名的人工智能工具&#xff0c;就像聊天机器人一样。Chat GPT会回答发送给它的所有查询。今天&#xff0c;我将通过集成 OpenAI API (ChatGPT)构建一个简单的类似 ChatGPT 的 android 应用程序&#xff0c;我们可以在其…

【docker_centos7】docker在centos7中如何安装??

Docker &#xff1f;&#xff1f;&#xff1f;What&#xff1f;&#xff1f;&#xff1f; Docker是一种开源的容器化平台&#xff0c;可以让开发者轻松地构建、打包、运输和部署应用程序。Docker容器是轻量级的、可移植的、自包含的软件包&#xff0c;其中包含了应用程序和其所…

Pytorch pth 格式转ONNX 格式

目录 背景介绍 安装依赖库 转换成onnx 格式 ONNX 转换成TensorRT 格式 背景介绍 PyTorch 训练的模型&#xff0c;需要在Jetson nano 上部署&#xff0c;jetson 原生提供了TensorRT 的支持&#xff0c;所以一个比较好的方式是把它转换成ONNX 格式&#xff0c;然后在通过ONNX …