Web开发-PHP应用&文件操作安全&上传下载&任意读取删除&目录遍历&文件包含

知识点:

1、安全开发-原生PHP-文件安全操作

2、安全开发-原生PHP-上传读取删除包含等

3、安全开发-原生PHP-代码审计文件安全

一、演示案例-WEB开发-文件安全-上传下载读取

文件上传

bash 复制代码
$_FILES:PHP中一个预定义的超全局变量,用于在上传文件时从客户端接收文件,并将其保存到服务器上。它是一个包含上传文件信息的数组,包括文件名、类型、大小、临时文件名等信息。
$_FILES["表单值"]["name"] 获取上传文件原始名称
$_FILES["表单值"]["type"] 获取上传文件MIME类型
$_FILES["表单值"]["size"] 获取上传文件字节单位大小
$_FILES["表单值"]["tmp_name"] 获取上传的临时副本文件名
$_FILES["表单值"]["error"] 获取上传时发生的错误代码
move_uploaded_file() 将上传的文件移动到指定位置的函数

文件下载

bash 复制代码
修改HTTP头实现文件读取解析下载:
header("Content-Type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"" . $file . "\"");
header("Content-Length: " . filesize($file));
readfile($file);



文件读取

1、file_get_contents() 读取文件内容



2、fopen()、fread() 文件打开读入



二、演示案例-WEB开发-文件安全-删除遍历包含

文件删除

bash 复制代码
unlink() 文件删除函数
调用命令删除:system shell_exec exec等

文件显示(目录遍历)

bash 复制代码
1.打开目录读取文件列表
2.递归循环读取文件列表
3.判断是文件还是文件夹
4.PHP.INI目录访问控制

is_dir() 函数用于检查指定的路径是否是一个目录

opendir() 函数用于打开指定的目录,返回句柄,用来读取目录的文件和子目录

readdir() 函数用于从打开的目录句柄中读取目录中的文件和子目录


open_basedir:PHP.INI中的设置用来控制脚本程序访问目录

scandir() 函数返回指定目录中的文件和目录列表,以数组形式返回

ini_set('open_basedir',DIR); 设置配置文件中,只能访问本目录

文件包含

include


require


include_once


require_once

三、演示案例-WEB开发-文件安全-代码审计案例

1、Rrzcms-遍历读取

https://xz.aliyun.com/t/10932


黑盒角度







白盒角度





2、Metinfo-文件下载

https://mp.weixin.qq.com/s/te4RG0yl_truE5oZzna3Eg




3、Xhcms-文件包含

https://xz.aliyun.com/t/11310


相关推荐
奥格列的魔法拖鞋~5 小时前
Docker-LNMP架构 创建多项目- 单个ngixn代理多个PHP容器服务
nginx·docker·eureka·架构·php·lnmp
皓空揽月6 小时前
php+apache+nginx 更换域名
nginx·php·apache
我不是立达刘宁宇9 小时前
php危险函数,二.assert()[现版本已弃用]
开发语言·php
liulanba12 小时前
NAT 和 PNAT
开发语言·php
nvvas1 天前
PHP imagick扩展安装以及应用
php
Websites1 天前
Hyperf 百度翻译接口实现方案
开发语言·自然语言处理·php·自动翻译
yzx9910131 天前
PHP 开发全解析:从基础到实战的进阶之路
开发语言·php
梦吉网络1 天前
在线进销存系统高效管理网站源码搭建可二开
php·网站搭建
啊阿狸不会拉杆1 天前
《算法导论》第 24 章 - 单源最短路径
开发语言·数据结构·c++·算法·php
衍余未了1 天前
Centos9傻瓜式linux部署CRMEB 开源商城系统(PHP)
开发语言·php