本篇文章主要是对php中$_files的使用方法及注意事项进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
$_files:经由 http post 文件上传而提交至脚本的变量,类似于旧数组$http_post_files 数组(依然有效,但反对使用)详细信息可参阅 post方法上传
$_files数组内容如下:
$_files['myfile']['name'] 客户端文件的原名称
$_files['myfile']['type'] 文件的 mime类型,需要浏览器提供该信息的支持,例如image/gif
$_files['myfile']['size'] 已上传文件的大小,单位为字节
$_files['myfile']['tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定,但用 putenv() 函数设置是不起作用的
$_files['myfile']['error'] 和该文件上传相关的错误代码,['error'] 是在 php 4.2.0版本中增加的,下面是它的说明:(它们在php3.0以后成了常量)
upload_err_ok 值:0; 没有错误发生,文件上传成功
upload_err_ini_size 值:1; 上传的文件超过了 php.ini 中 upload_max_filesize选项限制的值
upload_err_form_size 值:2;上传文件的大小超过了 html 表单中 max_file_size 选项指定的值
upload_err_partial 值:3; 文件只有部分被上传
upload_err_no_file 值:4;没有文件被上传, 值:5; 上传文件大小为0
注:
1. 文件被上传结束后,默认地被存储在了临时目录中,这时必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用php的copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。
2. 在 php 4.1.0 版本以前该数组的名称为 $http_post_files,它并不像$_files 一样是自动全局变量。php 3 不支持 $http_post_files数组。
3. 用form上传文件时,一定要加上属性内容enctype=multipart/form-data,否则用$_files[filename]获取文件信息时会报异常。
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.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 表单的一些注意项列举如下:
ff9c23ada1bcecdd1a0fb5d5a0f18437 标签的 enctype 属性规定了在提交表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用 multipart/form-data。
d5fd7aea971a85678ba271703566ebfd 标签的 type=file 属性规定了应该把输入作为文件来处理。举例来说,当在浏览器中预览时,会看到输入框旁边有一个浏览按钮。
注释:允许用户上传文件是一个巨大的安全风险。请仅仅允许可信的用户执行文件上传操作。
以上就是php $_files的使用方法的详细内容。