php文件上传
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>upload files</title> </head> <body> <form action="upload.php" enctype="multipart/form-data" method="post"> <input type="hidden" name="MAX_FILE_SIZE" value="10000" /> 上传文件:<input type="file" name="file"/> <input type="submit" value="上传" /> </form> </body> </html>
upload.php <?php print_r($_FILES); ?>
Array ( [file] => Array ( [name] => 照片文件.jpg [type] => image/jpeg [tmp_name] => F:\wamp\tmp\php41BB.tmp [error] => 0 [size] => 73886 ) )
//判断是否是POST上传过来的文件 if(!is_uploaded_file($tempName)){ exit("不是通过HTTP POST方式上传上来的"); } // 判断文件上传的类型 if(!in_array($fileType, $typeList)){ exit("上传的文件不是指定类型"); } //避免用户上传恶意文件,如把病毒文件扩展名改为图片格式 if(!getimagesize($tempName)){ exit("上传的文件不是图片"); } // 验证文件上传大小 if($fileSize>100000){ //对特定表单的上传文件限制大小 exit("上传文件超出限制大小"); } //避免上传文件的中文名乱码,把iconv抓取到的字符编码从utf-8转为gbk输出 $fileName=iconv("UTF-8", "GBK", $fileName); //在图片名称后加入时间戳,避免重名文件覆盖 $fileName=str_replace(".", time().".", $fileName); // 移动文件到指定位置 if(move_uploaded_file($tempName, "uploads/".$fileName)){ echo "上传文件成功!"; }else{ echo "上传文件失败"; }
file_exists 检查文件或目录是否存在
is_uploaded_file 判断文件是否是通过 HTTP POST 上传的
move_uploaded_file 将上传的文件移动到新位置
is_writable 判断给定的文件名是否可写
iconv 字符编码互转
str_replace 字符串替换(更改文件名,防重名)
getimagesize 检查是否为图片文件(其他类型的文件就算后缀名改了也能被检测到)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现