文件域的作用是实现文件或图片的上传。文件域有一个特有的属性,用于指定上传的文件类型,如果需要显示上传文件的类型,则可以通过设置该属性来完成。
在实现开发过程中,文件或者图片上传在一些网站应用中是必不可少的一部分。比如个人博客上传个性头像,一些论坛分享好的学习资料等等,这就涉及到使用表单处理文件上传的知识,在php中 我们可以使用$_FILES这个全局数组来处理。下面就看看基本的文件上传处理部分。首先要说明的,能够上传文件必定是一个安全隐患,所以在开发这部分功能时,一定要注意网站的安全性。而在这里所探讨的只是基本的文件上传部分,提供的是PHP文件上传基本的知识,让朋友们了解最简单的原理和代码知识,关于安全性这方面考虑的较少。
$_FILES:经由 HTTP 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 版本中增加的。
$_FILES["file"]["error"]中的["error"]值情况:
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)新创建一个 index.php 动态页,创建一个 form 表单,添加一个文件域和一个提交按钮,其主要的代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>form</title> </head> <body> <form action="index.php" method="post" name="form1"> <input type="file" name="file" size="15"> <input type="submit" name="upload" value="上传文件"> </form> </body> </html>
说明:本实例实现的是获取文件域的值,并没有实现图片的上传,因此不需要设置