0

0

【求助】关于is_uploaded_file()的使用

php中文网

php中文网

发布时间:2016-06-23 14:17:53

|

1341人浏览过

|

来源于php中文网

原创

各位大牛晚上好!小弟刚接触PHP,在看一些教材的时候有说到这样一段话:

通过is_uploaded_file()函数对上传的文件进行判断,可以确保恶意用户无法欺骗脚本去访问本不能访问的文件,例如/etc/password

小弟的问题来了:如果真的没有用is_uploaded_file()来检测的话,那么“恶意用户”如何做到欺骗脚本去访问本不能访问的内容呢?不解...望大牛可以略微解释得通俗易懂一些,谢谢!


回复讨论(解决方案)

对于 php5.4 及更高版本这个函数已经没有意义了

操作上传的文件,一般使用 move_uploaded_file 函数,它内部也会调用 is_uploaded_file
当然也不能排除你偏要用 copy 函数,所以才有了 is_uploaded_file
显然如果是
copy('/etc/password', './ps')
那么就可以将系统的口令文件复制了过来
当然,你的代码是不会这样写的,你可能会写作
copy($file_tmp, $target)
如果 $file_tmp 的值是 /etc/password 的话,仍然可以将系统的口令文件复制了过来的
所以要对这个 $file_tmp 做 is_uploaded_file 检查

那么你会说 $file_tmp 是程序中的变量,人家怎么能赋值呢?
问题就出在 php 的自动注册开关上
当 register_globals = on 的时候
传入的数据都会变成全局变量,比如 ?file_tmp=xxxx 就会有一个 $file_tmp 变量,值为 xxxx
而名为 file 的上传控件也会产生一个 $file_tmp 
到此,你已经看到可以通过 url 参数来骗过 php

正因为如此
php 5.3 默认 register_globals = off,并不建议打开
php 5.4 及更高版本 register_globals 开关已经取消

对于 php5.4 及更高版本这个函数已经没有意义了

操作上传的文件,一般使用 move_uploaded_file 函数,它内部也会调用 is_uploaded_file
当然也不能排除你偏要用 copy 函数,所以才有了 is_uploaded_file
显然如果是
copy('/etc/password', './ps')
那么就可以将系统的口令文件复制了过来
当然,你的代码是不会这样写的,你可能会写作
copy($file_tmp, $target)
如果 $file_tmp 的值是 /etc/password 的话,仍然可以将系统的口令文件复制了过来的
所以要对这个 $file_tmp 做 is_uploaded_file 检查

那么你会说 $file_tmp 是程序中的变量,人家怎么能赋值呢?
问题就出在 php 的自动注册开关上
当 register_globals = on 的时候
传入的数据都会变成全局变量,比如 ?file_tmp=xxxx 就会有一个 $file_tmp 变量,值为 xxxx
而名为 file 的上传控件也会产生一个 $file_tmp 
到此,你已经看到可以通过 url 参数来骗过 php

正因为如此
php 5.3 默认 register_globals = off,并不建议打开
php 5.4 及更高版本 register_globals 开关已经取消

谢谢~现在明白了~

默默收藏

知道怎么回事了,学习了

相关专题

更多
c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

42

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

46

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

202

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

341

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

16

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

100

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

73

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

75

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

67

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

微信小程序开发之API篇
微信小程序开发之API篇

共15课时 | 1.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号