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,一经查实,立即删除!

相关文章

python使用MkDocs自动生成文档

python使用MkDocs自动生成文档 前言使用MkDocs环境相关资料使用介绍项目结构配置文件注释生成文档的配置运行与构建部署 实践的项目 前言 python代码注释风格有很多&#xff0c;比较主流的有 reStructuredText风格、numpy风格、Google风格。 自动生成文档的工具也有很多&…

IO流(1)

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

C++标准模板(STL)- 变参数函数

变参数函数 变参数函数是接收可变数量参数的函数&#xff08;例如 std::printf &#xff09;。 为声明变参数函数&#xff0c;要以省略号为最后的形参&#xff0c;例如 int printf(const char* format, ...); 。语法上的额外细节、自动参数转换及替用项见变参数。 为从函数…

L9110S电机控制模块

1.L9110s控制小车前进后退左右 接通VCC&#xff0c;GND 模块电源指示灯亮&#xff0c; 以下资料来源官方&#xff0c;但是仍需我们调制 &#xff08;前进&#xff09;&#xff1a; L1A输入低电平&#xff0c;L1B输入高电平 R1A输入低电平&#xff0c;R1B输入高电平 &a…

智能优化算法 | Matlab实现DBO蜣螂优化算法

智能优化算法 | Matlab实现DBO蜣螂优化算法 文章目录 智能优化算法 | Matlab实现DBO蜣螂优化算法文章概述源码设计文章概述 智能优化算法 | Matlab实现DBO蜣螂优化算法 源码设计 % ----------------------------------------------------------------------------------------…

(函数)判断一句话中最长的单词(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 };//获取用户输入字符…

【HM】使用@Builder装饰器,顺便要知道@BuilderParam,且注意this的指向

Builder装饰器修饰的函数是自定义构造函数&#xff0c;可以定义组件内构造函数&#xff0c;也可以定义全局构造函数&#xff0c;提供给外部组件使用。 就是通过自定义构造函数&#xff0c;可以把build(){// UI元素} 构造函数内的UI部分&#xff0c;抽离出来封装成一个函数&…

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; 副业一…

7岁男孩学什么编程好一些:探索儿童编程的四大领域与未来潜能

7岁男孩学什么编程好一些&#xff1a;探索儿童编程的四大领域与未来潜能 在数字化时代&#xff0c;编程已成为一项重要的技能。对于7岁的男孩来说&#xff0c;选择适合的编程学习内容至关重要。那么&#xff0c;究竟哪些编程课程更适合这个年龄段的孩子呢&#xff1f;本文将从…

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

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

python中的预编译正则表达式

预编译正则表达式指的是使用Python的re模块中的re.compile()函数提前将正则表达式的字符串形式编译成一个正则表达式对象。这样&#xff0c;当你需要在多个地方或多次使用同一个正则表达式时&#xff0c;你可以重用这个编译后的对象&#xff0c;而不是在每次使用时重新编译表达…

404.左叶子之和

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

Turtle中circle用法详解

在Python的Turtle图形库中&#xff0c;circle方法是一个非常灵活的工具&#xff0c;它允许我们以简单的方式绘制圆或圆的一部分。本文将深入探讨circle方法&#xff0c;特别关注radius和extent参数的用途及其正负值的意义。 一、circle方法概览 首先&#xff0c;让我们了解一…

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

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

JavaScript第五讲:事件,条件循环语句,错误处理

前言 在编程的世界里&#xff0c;事件、条件和循环语句、以及错误处理是构建任何复杂程序或应用的基石。无论是开发一个简单的网页交互&#xff0c;还是构建一个庞大的企业级系统&#xff0c;这些基础概念都扮演着至关重要的角色。今天星途将通过这篇文章&#xff0c;分别深入…

java中判断String类型为空和null的方法

1.判断一个String类型的变量是否为空&#xff08;即长度为0&#xff09;或者为null 在Java中&#xff0c;判断一个String类型的变量是否为空&#xff08;即长度为0&#xff09;或者为null&#xff0c;通常需要使用两个条件语句来进行检查。这是因为null表示变量没有引用任何对…

01PCB设计概述

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