php之文件操作代码审计

1 PHP文件操作函数

1.1 PHP文件操作函数

  • 文件包含 include/require/include_once/require_once

  • 文件读取 file_get_contents/fread/readfile/file

  • 文件写入 file_put_contents/fwrite/mkdir/fputs

  • 文件删除 unlink/rmdir

  • 文件上传 move_uploaded_file/copy/rename

1.2 文件上传流程

  • 检查文件大小、后缀、类型

  • 检查文件内容(如图片头)

  • 提取文件后缀

  • 生成新文件名

  • 将上传临时文件拷贝到新文件名位置

1.3 文件上传逻辑常见错误

  • 只检查文件类型不检查文件后缀

  • 文件后缀黑名单导致遗漏

  • 使用原始文件名,导致\0截断等漏洞

2 taocms靶场

2.1 taocms后台任意文件上传

1.点击上传弹出一个小的弹窗

2 参数有file和upload但是fil和upload设置文件


3 查看源码发现

发现几乎将php文件上传限制了

4 在新建空白3.php文件

5 在3.php文件插入一句话木马

6 查看3.php文件所在位置以及访问文件

发现新建文件哪里代码没有做限制

2.2 tomccms任意文件删除

1 先新建1.php文件

2 抓取删除3.php的数据包

3 删除的3.php文件修改为1.php

表示删除上成功

4 查看file.php文件以及参数del的代码模块

/**  * 删除文件或目录  */  
function del(){  // 获取当前对象的realpath属性作为路径  $path = $this->realpath;  // 检查路径是否可写,如果不是,则显示无删除权限的消息  if (!is_writable($path)) {  Base::showmessage('无删除权限');  return; // 添加返回语句,避免后续代码继续执行  }  // 检查路径是否为一个目录  if (is_dir($path)) {  // 如果目录内的文件(包括.和..)数量大于2,则目录非空,不能删除  if (count(scandir($path)) > 2) {  Base::showmessage('目录非空,不能删除');  return; // 添加返回语句,避免后续代码继续执行  }  // 删除目录  rmdir($path);  } else {  // 如果路径不是一个目录,则尝试删除文件  unlink($path);  }  // 获取删除项的路径信息  $info = pathinfo($this->path); // 注意:这里使用了$this->path而不是$path,可能是一个错误  // 显示删除成功的消息,并跳转到文件管理列表页面  Base::showmessage('删除成功', 'admin.php?action=file&ctrl=lists&path=' . $info['dirname']);  
}

代码分析

this−>realpath的来源:如果‘this->realpath`的值来自用户输入或不可信的源,并且没有进行适当的验证和清理,那么攻击者可能会尝试删除不应该被删除的文件或目录。 this−>path与path:在函数内部,您使用了$this->realpath作为$path,但在显示成功消息时使用了$this->path。这可能会导致显示错误的路径信息或引发未定义行为(如果$this->path没有被正确设置)。 URL跳转:在显示成功消息时,您直接使用了$info['dirname']作为URL参数的一部分。如果$info['dirname']可以被用户控制或伪造,那么攻击者可能会被重定向到不希望的页面或执行未授权的操作。但是,这通常不被视为“任意文件删除漏洞”,而是URL重定向或注入的问题。 任意文件删除漏洞:要构成任意文件删除漏洞,攻击者需要能够控制$this->realpath的值,以便指定要删除的文件或目录。如果$this->realpath的值直接来自用户输入,并且没有进行验证和过滤,那么这就是一个漏洞。

5 在data文件下新建一个名为install8.lock

6 将删除文件修改为我们要删除的文件

那么确定村子啊任意文件删除漏洞

3 beecms靶场

3.1 beecms靶任意文件删除

1 使用seay的全局搜索unlink

2 点击查看第一个

代码分析

我们能不构建任意的vlaued的值

成为任意文件删除漏洞

3 漏洞复现

在upload文件下的新建1.php文件

在data文件下的新建install9.lock文件

burp抓包并删除upload文件下的1.php

查看upload文件夹下没有1.php

尝试删除instal9.lock文件

查看data文件下已经没有install9.lock

3.2 beecms意外的sql注入

1 审计第二个漏洞


2 对代码分析

// 删除栏目  
// 检查动作是否为删除(del)  
elseif($action=='del'){  // 检查当前用户是否有删除栏目的权限  if(!check_purview('cate_del')){  // 如果没有权限,则输出错误消息并终止执行  msg('<span style="color:red">操作失败,你的权限不足!</span>');  }  // 获取要删除的栏目ID,并进行整型转换,防止SQL注入  $id=intval($_GET['id']);  // 判断该栏目下是否有内容  // 如果有内容,则不允许直接删除栏目,需先删除内容  $has_content=$GLOBALS['mysql']->fetch_rows("select id from ".DB_PRE."maintb where category=".$id);  if($has_content){  // 如果有内容,则输出错误消息并终止执行  msg('<span style="color:red">请先删除该栏目下的内容</span>');  }  // 递归删除子栏目(函数未在此段代码中给出)  del_cate_child($id,$lang);  // 删除当前栏目的所有子栏目(指定父ID)  $GLOBALS['mysql']->query('delete from '.DB_PRE.'category where cate_parent='.$id." and lang='".$lang."'");  // 删除当前栏目  $GLOBALS['mysql']->query('delete from '.DB_PRE.'category where id='.$id." and lang='".$lang."'");  // 检查缓存文件是否存在,如果存在则删除  if(file_exists(DATA_PATH.'cache_cate/cache_category'.$parent.'_'.$lang.'.php')){  unlink(DATA_PATH.'cache_cate/cache_category'.$parent.'_'.$lang.'.php');  }  // 重新缓存父栏目信息(函数未在此段代码中给出)  $GLOBALS['cache']->cache_category($parent,$lang);  // 重新缓存所有子栏目信息(函数未在此段代码中给出)  $GLOBALS['cache']->cache_category_child(0,$lang);  

此代码基本上没有错误

3 删除文件查看网络请求

4 对照代码分析

// 删除栏目  
// 检查动作是否为删除(del)  
elseif($action=='del'){  // 检查当前用户是否有删除栏目的权限  if(!check_purview('cate_del')){  // 如果没有权限,则输出错误消息并终止执行  msg('<span style="color:red">操作失败,你的权限不足!</span>');  }  // 获取要删除的栏目ID,并进行整型转换,防止SQL注入  $id=intval($_GET['id']);  // 判断该栏目下是否有内容  // 如果有内容,则不允许直接删除栏目,需先删除内容  $has_content=$GLOBALS['mysql']->fetch_rows("select id from ".DB_PRE."maintb where category=".$id);  if($has_content){  // 如果有内容,则输出错误消息并终止执行  msg('<span style="color:red">请先删除该栏目下的内容</span>');  }  // 递归删除子栏目(函数未在此段代码中给出)  del_cate_child($id,$lang);  // 删除当前栏目的所有子栏目(指定父ID)  $GLOBALS['mysql']->query('delete from '.DB_PRE.'category where cate_parent='.$id." and lang='".$lang."'");  // 删除当前栏目  $GLOBALS['mysql']->query('delete from '.DB_PRE.'category where id='.$id." and lang='".$lang."'");  // 检查缓存文件是否存在,如果存在则删除  if(file_exists(DATA_PATH.'cache_cate/cache_category'.$parent.'_'.$lang.'.php')){ 删除文件并命令为 cache_category_0_cn.php那么删除文件的  cache_category/../../cn.php直接返回到上一级目录unlink(DATA_PATH.'cache_cate/cache_category'.$parent.'_'.$lang.'.php');  }  // 重新缓存父栏目信息(函数未在此段代码中给出)  $GLOBALS['cache']->cache_category($parent,$lang);  // 重新缓存所有子栏目信息(函数未在此段代码中给出)  $GLOBALS['cache']->cache_category_child(0,$lang);

5 抓包尝试

现在data文件夹新建一个instal8.lock

抓包尝试

发现报sql错误,那么猜测是否存在SQL注入漏洞

6 根据报错信息查找内容

发现parent参数没有进行过滤那么存在sql注入

7 构建payload进行攻击

1%20or%20updatexml(1,concat(0x3e,database()),1)--+

爆出了数据库名称

3.3 beecms文件上传代码审计

1 在seay软件使用全局搜索move_uploaded_file参数

2 进入第一个进入漏洞详细并用在idea上进行代码分析


发现判断格式只有图片的格式可以进行任意文件上传

3 漏洞复现

burp抓包

修改
Content-Type: application/octet-stream
修改为
Content-Type: image/jpeg

并发送

重新查看图片

查看图片链接

4 进入第三个漏洞汇报

代码分析


发现只允许图片格式上传

payload发现

抓包复现

查看文件

3.4 beecms文件包含漏洞

1 在seay上使用全局搜索include($

2 在admin_channel.php文件第449行上找到导入字段存在文件包漏洞

3 在游览器上访问admin_channel.php地址

4 根据参数说明,编写路径

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

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

相关文章

IO流(1)

定义&#xff1a;存取和读取数据的解决方案 作用&#xff1a;用于读写数据&#xff08;本地文件、网络&#xff09; 分类&#xff1a; 一种是&#xff1a;输出流和输入流。 一种是&#xff1a;字节流和字符流。 字节流 字节流——FileOutputStream&#xff08;字节输出流&…

(函数)判断一句话中最长的单词(C语言)

一、运行结果&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>//声明函数&#xff1b; int aiphabetic(char); int longest(char[]);int main() {//初始化变量值&#xff1b;int i;char line[100] { 0 };//获取用户输入字符…

Gradle命令打包 Execution failed for task ‘:app:compileDebugJavaWithJavac错误

Gradle命令打包的时候遇到的&#xff0c;Gradle的java版本不对导致的&#xff0c;用的17&#xff0c;换成11的就能正常打包了。

大模型管理工具Ollama搭建及整合springboot

目录 一、Ollama介绍 1.1 什么是Ollama 1.2 Ollama特点与优势 二、Ollama本地部署 2.1 版本选择 2.2 下载安装包 2.3 执行安装 2.4 Ollama常用命令 三、使用Ollama部署千问大模型 3.1 千问大模型介绍 3.2 部署过程 四、springboot接入Ollama 4.1 引入Ollama依赖 4…

树莓派LCD显示屏安装驱动详细教程

使用LCD显示屏有两种方式&#xff0c;1.如果你已安装好树莓派官方系统&#xff0c;需要单独安装驱动才可点亮显示屏。 2. 也可以直接烧录我们提供的系统 里面已含驱动程序。 一&#xff1a;连接方式 按照下图方式连接好LCD显示屏与树莓派主板 二&#xff1a;安装系统镜像&…

6个适合在家做的副业兼职,做得好的月入过万,适合上班族和宝妈

嘿&#xff0c;亲爱的朋友们&#xff01;是不是常常觉得钱包瘪瘪&#xff0c;却又因为种种原因无法外出兼职&#xff1f; 别急&#xff0c;我来为大家揭秘几个在家也能轻松赚钱的靠谱副业&#xff0c;让你足不出户也能月入过万&#xff0c;从此告别财务烦恼&#xff01; 副业一…

1.5.3 基于Java配置方式使用Spring MVC

本实战教程主要介绍了如何使用Java配置方式来使用Spring MVC框架。相较于XML配置方式&#xff0c;Java配置方式提供了一种更为简洁和灵活的配置方法。 项目创建与配置 创建一个Jakarta EE项目&#xff0c;并设置项目名称和位置。选择Jakarta EE 10版本&#xff0c;不添加依赖&a…

404.左叶子之和

计算给定二叉树的所有左叶子之和。 示例&#xff1a; 思路&#xff1a; 通过父节点来判断七子节点是不是我们要收集的元素。因为如果遍历到孩子节点&#xff0c;我们无法判断它是左孩子还是右孩子。 后序遍历&#xff0c;左右中。 判断当前节点是不是左叶子是无法判断的&…

271 基于matlab的可调Q因子小波变换故障诊断

基于matlab的可调Q因子小波变换故障诊断&#xff0c;可用在轴承、齿轮、活塞等故障诊断中&#xff0c;程序中包含了原始TQWT工具箱和轴承振动信号信号的谱包络的求取。通过仿真数据、实际轴承数据说明了方法的效果。程序已调通&#xff0c;可直接运行。 271 可调Q因子小波变换 …

01PCB设计概述

PCB设计概述 EDA electronic design automatic 电子设计自动化&#xff08;利用计算机来实现电子设计&#xff09; 分为 &#xff1a; 微电子&#xff08;芯片设计&#xff09;、硬件板卡&#xff08;PCB设计&#xff09; 画原理图、画PCB布线 要会绘制原理图库、和封装图库 元…

LeetCode84:柱形图中最大的矩形

题目描述 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 代码 单调栈 class Solution { public:int largestRectangleArea(vector<int>& h…

AI 学习神器!大学生必备的 22个 AI 提示词模板

AI 学习神器&#xff01;大学生必备的 22个 AI 提示词模板 博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘…

6. MySQL 查询、去重、别名

文章目录 【 1. 数据表查询 SELECT 】1.1 查询表中所有字段使用 * 查询表的所有字段列出表的所有字段 1.2 查询表中指定的字段 【 2. 去重 DISTINCT 】【 3. 设置别名 AS 】3.1 为表指定别名3.2 为字段指定别名 【 5. 限制查询结果的条数 LIMIT 】5.1 指定初始位置5.2 不指定初…

基于优化Morlet小波的一维信号瞬态特征提取方法(MATLAB R2018A)

小波分析方法近些年逐步得到发展的一门数学分析技术&#xff0c;它对许多学科都有十分重要的影响。与傅立叶变换等其他传统方法相比&#xff0c;小波分解的方法中所用的小波基有着多种多样的结构&#xff0c;总结来说又包括正交小波系与非正交小波系。正交小波在信号处理领域目…

系统思考—思考快与慢

“膝反射思考做决策&#xff0c;你的公司能走多远&#xff1f;” 在快节奏的商业环境中&#xff0c;我们的大脑往往默认采用“快速直觉反应”模式来做决策&#xff0c;这种方式节省能量&#xff0c;属于我们认知的“系统一”。然而&#xff0c;仅依靠直觉反应&#xff0c;即所…

cleanmyMac有必要吗,什么软件可以替代clean my mac

最近总有苹果用户抱怨mac电脑变得非常卡顿&#xff0c;而且总会收到“您的启动磁盘几乎已经满了”的系统提示。提示出现的原因是我们长期未对电脑进行健康扫描和深度清理导致的。遇到这种情况&#xff0c;我们可以借助专业的电脑深度清理软件——CleanMyMac X&#xff0c;清理不…

Django中使用Celery和APScheduler实现定时任务

在之前的文章我们已经学习了Celery和APScheduler的基本使用&#xff0c;下面让我们来了解一下如何在Django中使用Celery和APScheduler Celery 1.前提工作 python 3.7 pip install celery pip install eventlet #5.0版本以下 pip install importlib-metadata4.8.3&#xff08…

从功能性磁共振成像(fMRI)数据重建音频

听觉是人类最重要的感官之一&#xff0c;它负责接收外部的听觉刺激&#xff0c;并将这些信息传递给大脑进行处理和理解。研究人员正致力于从神经科学和计算机科学两个领域探索人脑的听觉感知机制。一个关键目标是从人脑中解码神经信息&#xff0c;并重建原始的刺激。常见的大脑…

【上海大学计算机组成原理实验报告】六、内存系统实验

一、实验目的 学习内存访问机制。理解代码和数据的分区存放原理和技术。 二、实验原理 根据实验指导书的相关内容&#xff0c;地址寄存器MAR用来存放要进行读或写的存储器EM的地址。其内容经数据总线DBUS写入&#xff0c;因此必须在数据总线上具有数据后&#xff0c;配合MAR允…

认识微服务,认识Spring Cloud

1. 介绍 本博客探讨的内容如下所示 什么是微服务&#xff1f;什么是springcloud&#xff1f;微服务和springcloud有什么关系&#xff1f; 首先&#xff0c;没有在接触springcloud之前&#xff0c;我写的项目都是单体结构&#xff0c; 但随着网站的用户量越来越大&#xff0c;…