本文分为五个部分针对php上传文件进行分析讲解,具体内容如下
- 文件上传变量
- 将服务器上的临时文件移动到指定目录下
- php.ini上传相关配置
- error错误号
- 单文件上传实例
1.文件上传变量
1
2
3
4
5
6
7
8
9
10
11
12
|
//$_FILES:文件上传变量
#name 文件的名称
#type 文件的类型
#tmp_name 临时文件名
#size 文件的大小
#error 错误信息
$filename = $_FILES [ "myFile" ][ "name" ];
$type = $_FILES [ "myFile" ][ "type" ];
$tmp_name = $_FILES [ "myFile" ][ "tmp_name" ];
$size = $_FILES [ "myFile" ][ "size" ];
$error = $_FILES [ "myFile" ][ "error" ];
|
2.将服务器上的临时文件移动到指定目录下
1
2
3
4
5
6
|
//1.move_uploaded_file($tmp_name,$destination):将服务器上的临时文件移动到指定目录下
#上传后文件名字,移动成功返回true,否则返回false
move_uploaded_file( $tmp_name , "D:/" . $filename );
//2.copy($tmp_name,$destination)
copy ( $tmp_name , "D:/" . $filename );
|
3.php.ini上传相关配置
1
2
3
4
5
6
7
8
9
10
11
|
# file_uploads=On 支持HTTP上传
# upload_tmp_dir= "" 临时文件保存的目录
# upload_max_filesize=2M 允许上传文件的最大值
# max_file_uploads=20 允许一次上传的最大文件数
# post_max_size=8M post方式发送数据的最大值
# max_execution_time = 1 设置了脚本被解析器终止之前允许的最大执行时间,单位为秒,防止程序写的不好而占尽服务器资源
# max_input_time = 60 脚本解析输入数据允许的最大时间,单位为秒
# max_input_nesting_level = 64 设置输入变量的嵌套深度
# max_input_vars = 1000 接受多少输入的变量
# memory_limit = 128M 最大单线程的独立内存使用量
|
4.error错误号
1
2
3
4
5
6
7
8
|
# 0,没有错误发生,文件上传成功。
# 1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
# 2,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
# 3,文件只有部分被上传。
# 4,没有文件被上传。
# 6,找不到临时文件夹。
# 7,文件写入失败。
# 8,上传的文件被PHP扩展程序中断
|
5.单文件上传实例
form.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
<!doctype html>
< html lang = "en" >
< head >
< meta charset = "UTF-8" >
< title >Document</ title >
</ head >
< body >
< form action = "fileUpload.php" method = "post" enctype = "multipart/form-data" >
请选择你要上传的文件:
< input type = "file" name = "myFile" >< br >
< input type = "submit" value = "上传文件" >
<!--限制客户端上传文件的最大值 隐藏域另起一行-->
<!--<input type="hidden" name="MAX_FILE_SIZE" value="字节数">-->
<!--accept设置上传文件的类型-->
<!--<input type="file" name="myfile" accept="image/jpg,image/png,image/gif">-->
</ form >
</ body >
</ html >
|
fileUpload.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
header( "content-type:text/html;charset:utf-8" );
$fileInfo = $_FILES [ "myFile" ];
$filename = $fileInfo [ "name" ];
$type = $fileInfo [ "type" ];
$error = $fileInfo [ "error" ];
$size = $fileInfo [ "size" ];
$tmp_name = $fileInfo [ "tmp_name" ];
$maxSize =2*1024*1024; //允许的最大值
$allowExt = array ( "jpeg" , "jpg" , "gif" );
$flag = true; //检测是否为真实的图片类型
//判断错误号
if ( $error == 0){
//判断上传文件的大小
if ( $size > $maxSize ){
exit ( "上传文件过大" );
}
//检测文件类型
//取出文件扩展名
$ext = pathinfo ( $filename ,PATHINFO_EXTENSION);
if (!in_array( $ext , $allowExt )){
exit ( "非法文件类型" );
}
//检测是否为真实的图片类型
if ( $flag ){
if (@! getimagesize ( $tmp_name )){
exit ( "不是正的图片类型" );
}
}
//创建目录
$path = "D:/test/" ;
if (! file_exists ( $path )){
mkdir ( $path ,0777,true);
chmod ( $path ,0777);
}
//确保文件名唯一,防止重名覆盖
$uniName = md5(uniqid(microtime(true),true)). "." . $ext ;
$destination = $path . $uniName ;
if (@move_uploaded_file( $tmp_name , $destination )){
echo "上传成功" ;
} else {
echo "上传失败" ;
}
} else {
switch ( $error ){
case 1:
case 2:
case 3:
case 4:
case 6:
case 7:
case 8:
echo "上传错误" ;
break ;
}
}
|
希望本文所述对大家学习php程序设计有所帮助。