PHP 文件上传

通过 PHP,可以把文件上传到做事器。

本章节实例在 test 项眼前完成,目录构造为:

test|-----upload # 文件上传的目录|-----form.html # 表单文件|-----upload_file.php # php 上传代码

php上传临时目录权限PHP法式员从入门到佛系第三十三弹PHP 文件上传 Docker

创建一个文件上传表单

许可用户从表单上传文件是非常有用的。

请看下面这个供上传文件的 HTML 表单:

<html><head><meta charset=\"大众utf-8\公众><title>XIONGT(XIONGT.com)</title></head><body><form action=\"大众upload_file.php\公众 method=\公众post\"大众 enctype=\"大众multipart/form-data\"大众> <label for=\"大众file\公众>文件名:</label> <input type=\"大众file\公众 name=\公众file\"大众 id=\"大众file\"大众><br> <input type=\公众submit\"大众 name=\"大众submit\公众 value=\公众提交\"大众></form></body></html>

将以上代码保存到 form.html 文件中。

有关上面的 HTML 表单的一些把稳项列举如下:

<form> 标签的 enctype 属性规定了在提交表单时要利用哪种内容类型。
在表单须要二进制数据时,比如文件内容,请利用 \"大众multipart/form-data\公众。
<input> 标签的 type=\"大众file\公众 属性规定了该当把输入作为文件来处理。
举例来说,当在浏览器中预览时,会看到输入框阁下有一个浏览按钮。

注释:许可用户上传文件是一个巨大的安全风险。
请仅仅许可可信的用户实行文件上传操作。

创建上传脚本

\公众upload_file.php\公众 文件含有供上传文件的代码:

<?phpif ($_FILES[\"大众file\"大众][\"大众error\"大众] > 0){ echo \"大众缺点:\"大众 . $_FILES[\"大众file\公众][\"大众error\"大众] . \公众<br>\"大众;}else{ echo \"大众上传文件名: \"大众 . $_FILES[\公众file\"大众][\"大众name\"大众] . \"大众<br>\公众; echo \公众文件类型: \公众 . $_FILES[\公众file\"大众][\公众type\公众] . \"大众<br>\公众; echo \"大众文件大小: \"大众 . ($_FILES[\"大众file\公众][\公众size\"大众] / 1024) . \"大众 kB<br>\公众; echo \"大众文件临时存储的位置: \"大众 . $_FILES[\公众file\"大众][\公众tmp_name\公众];}?>

通过利用 PHP 的全局数组 $_FILES,你可以从客户打算机向远程做事器上传文件。

第一个参数是表单的 input name,第二个下标可以是 \"大众name\公众、\公众type\公众、\"大众size\"大众、\"大众tmp_name\公众 或 \"大众error\"大众。
如下所示:

$_FILES[\公众file\"大众][\"大众name\"大众] - 上传文件的名称$_FILES[\"大众file\"大众][\"大众type\"大众] - 上传文件的类型$_FILES[\"大众file\公众][\"大众size\"大众] - 上传文件的大小,以字节计$_FILES[\"大众file\公众][\"大众tmp_name\"大众] - 存储在做事器的文件的临时副本的名称$_FILES[\公众file\"大众][\"大众error\公众] - 由文件上传导致的缺点代码

这是一种非常大略文件上传办法。
基于安全方面的考虑,您应该增加有关许可哪些用户上传文件的限定。

上传限定

在这个脚本中,我们增加了对文件上传的限定。
用户只能上传 .gif、.jpeg、.jpg、.png 文件,文件大小必须小于 200 kB:

<?php// 许可上传的图片后缀$allowedExts = array(\"大众gif\"大众, \"大众jpeg\"大众, \公众jpg\"大众, \"大众png\"大众);$temp = explode(\"大众.\"大众, $_FILES[\"大众file\公众][\"大众name\公众]);$extension = end($temp); // 获取文件后缀名if ((($_FILES[\"大众file\"大众][\公众type\公众] == \"大众image/gif\"大众)|| ($_FILES[\公众file\"大众][\公众type\"大众] == \公众image/jpeg\公众)|| ($_FILES[\"大众file\"大众][\"大众type\"大众] == \"大众image/jpg\"大众)|| ($_FILES[\"大众file\公众][\"大众type\公众] == \公众image/pjpeg\公众)|| ($_FILES[\"大众file\"大众][\"大众type\公众] == \公众image/x-png\"大众)|| ($_FILES[\公众file\"大众][\"大众type\公众] == \"大众image/png\公众))&& ($_FILES[\"大众file\公众][\"大众size\"大众] < 204800) // 小于 200 kb&& in_array($extension, $allowedExts)){ if ($_FILES[\"大众file\公众][\"大众error\公众] > 0) { echo \公众缺点:: \"大众 . $_FILES[\"大众file\"大众][\公众error\"大众] . \"大众<br>\"大众; } else { echo \"大众上传文件名: \"大众 . $_FILES[\"大众file\"大众][\"大众name\公众] . \公众<br>\"大众; echo \公众文件类型: \"大众 . $_FILES[\"大众file\公众][\公众type\公众] . \公众<br>\公众; echo \"大众文件大小: \"大众 . ($_FILES[\"大众file\"大众][\公众size\"大众] / 1024) . \"大众 kB<br>\"大众; echo \"大众文件临时存储的位置: \"大众 . $_FILES[\"大众file\公众][\"大众tmp_name\"大众]; }}else{ echo \"大众造孽的文件格式\"大众;}?>

保存被上传的文件

上面的实例在做事器的 PHP 临时文件夹中创建了一个被上传文件的临时副本。

这个临时的副本文件会在脚本结束时消逝。
要保存被上传的文件,我们须要把它拷贝到其余的位置:

<?php// 许可上传的图片后缀$allowedExts = array(\"大众gif\公众, \"大众jpeg\"大众, \"大众jpg\"大众, \公众png\"大众);$temp = explode(\"大众.\"大众, $_FILES[\"大众file\"大众][\公众name\"大众]);echo $_FILES[\公众file\"大众][\"大众size\公众];$extension = end($temp); // 获取文件后缀名if ((($_FILES[\"大众file\公众][\公众type\"大众] == \"大众image/gif\公众)|| ($_FILES[\公众file\"大众][\公众type\"大众] == \"大众image/jpeg\"大众)|| ($_FILES[\"大众file\"大众][\"大众type\"大众] == \"大众image/jpg\公众)|| ($_FILES[\公众file\"大众][\"大众type\公众] == \"大众image/pjpeg\公众)|| ($_FILES[\"大众file\"大众][\"大众type\"大众] == \公众image/x-png\"大众)|| ($_FILES[\公众file\"大众][\公众type\"大众] == \公众image/png\"大众))&& ($_FILES[\"大众file\"大众][\"大众size\"大众] < 204800) // 小于 200 kb&& in_array($extension, $allowedExts)){ if ($_FILES[\"大众file\公众][\"大众error\"大众] > 0) { echo \公众缺点:: \公众 . $_FILES[\"大众file\公众][\"大众error\公众] . \"大众<br>\公众; } else { echo \"大众上传文件名: \公众 . $_FILES[\"大众file\公众][\"大众name\"大众] . \"大众<br>\"大众; echo \"大众文件类型: \"大众 . $_FILES[\"大众file\公众][\"大众type\"大众] . \"大众<br>\"大众; echo \"大众文件大小: \"大众 . ($_FILES[\"大众file\"大众][\"大众size\"大众] / 1024) . \"大众 kB<br>\公众; echo \"大众文件临时存储的位置: \公众 . $_FILES[\"大众file\公众][\"大众tmp_name\"大众] . \"大众<br>\"大众; // 判断当期目录下的 upload 目录是否存在该文件 // 如果没有 upload 目录,你须要创建它,upload 目录权限为 777 if (file_exists(\公众upload/\"大众 . $_FILES[\"大众file\"大众][\"大众name\"大众])) { echo $_FILES[\"大众file\"大众][\"大众name\公众] . \"大众 文件已经存在。
\公众; } else { // 如果 upload 目录不存在该文件则将文件上传到 upload 目录下 move_uploaded_file($_FILES[\"大众file\"大众][\"大众tmp_name\"大众], \"大众upload/\"大众 . $_FILES[\"大众file\公众][\公众name\公众]); echo \公众文件存储在: \"大众 . \公众upload/\公众 . $_FILES[\"大众file\公众][\"大众name\公众]; } }}else{ echo \"大众造孽的文件格式\"大众;}?>

上面的脚本检测了文件是否已存在,如果不存在,则把文件拷贝到名为 \"大众upload\"大众 的目录下。