文件上传一般有下面2种方式:
有两种:
1、标准input表单方式,典型的用$_FILES进行接收;
2、以Base64的方式进行传送,一般是AJAX异步上传。
第一种
标准的input表单方式,适用于大文件进行上传,同时支持批量。html代码关键的几句:
1
2
3
4
|
< input type = "file" name = "id_pic[]" accept = "image/*" class = "form-control" multiple />
< input type = "submit" value = "上传 " />
</ form >
|
不同的name时:
1
2
3
4
5
|
< form enctype = "multipart/form-data" method = "post" action = "upload.php" ">
< input type = "file" name = "id_pic_1" accept = "image/*" class = "form-control" />
< input type = "file" name = "id_pic_2" accept = "image/*" class = "form-control" />
< input type = "submit" value = "上传 " />
</ form >
|
其中enctype="multipart/form-data"对于文件上传是必不可少的。另外type="file"设置input类型,accept="image/*"指定优先上传图片(MIME 参考手册)。multiple支持一次选多个文件,pic[]以数组的形式接收多个文件。手机端端还可以加入参数capture="camera"选择摄像头拍照上传。
后端处理:
通过$_FILES获取上传的文件。
$files = $_FILES;
传多个文件时,如果name不同,则返回的$_FILES数组格式不同。
name相同时:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
|
array (1) {
[ "id_pic" ] => array (5) {
[ "name" ] => array (2) {
[0] => string(5) "1.jpg"
[1] => string(5) "2.jpg"
}
[ "type" ] => array (2) {
[0] => string(10) "image/jpeg"
[1] => string(10) "image/jpeg"
}
[ "tmp_name" ] => array (2) {
[0] => string(27) "C:\Windows\Temp\php7A7E.tmp"
[1] => string(27) "C:\Windows\Temp\php7A7F.tmp"
}
[ "error" ] => array (2) {
[0] => int(0)
[1] => int(0)
}
[ "size" ] => array (2) {
[0] => int(77357)
[1] => int(56720)
}
}
}
|
name不相同时:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
array (2) {
[ "id_pic_1" ] => array (5) {
[ "name" ] => string(5) "1.jpg"
[ "type" ] => string(10) "image/jpeg"
[ "tmp_name" ] => string(27) "C:\Windows\Temp\phpBBEE.tmp"
[ "error" ] => int(0)
[ "size" ] => int(77357)
}
[ "id_pic_2" ] => array (5) {
[ "name" ] => string(5) "2.jpg"
[ "type" ] => string(10) "image/jpeg"
[ "tmp_name" ] => string(27) "C:\Windows\Temp\phpBBEF.tmp"
[ "error" ] => int(0)
[ "size" ] => int(56720)
}
}
|
在对$_FILES进行foreach遍历时,前面那种输出格式不大方便。后面那种就可以直接遍历。我们可以写个方法进行统一转换:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
function dealFiles( $files ) {
$fileArray = array ();
$n = 0;
foreach ( $files as $key => $file ){
if ( is_array ( $file [ 'name' ])) {
$keys = array_keys ( $file );
$count = count ( $file [ 'name' ]);
for ( $i =0; $i < $count ; $i ++) {
$fileArray [ $n ][ 'key' ] = $key ;
foreach ( $keys as $_key ){
$fileArray [ $n ][ $_key ] = $file [ $_key ][ $i ];
}
$n ++;
}
} else {
$fileArray = $files ;
break ;
}
}
return $fileArray ;
}
|
好,前面讲到后端如何处理接收到的$_FILES数组,并转换成统一格式。接下来任务主要是:
1、检测上传的文件是否非法;
2、检测上传的文件是否超过大小;
3、检测保存的路径是否存在,是否可写;
4、文件重命名;
其中上传过程中用到了个很重要的函数:move_uploaded_file(filename , $destination )进行文件移动操作。将$_FILES['id_pic']['tmp_name']移动到新的路径里。当然,移动前可以用is_uploaded_file($_FILES['id_pic']['tmp_name'])进行判断文件是否正常上传的。
多文件上传则是循环的方法多次使用move_uploaded_file()进行移动操作。
第二种
主要以上传图片为主。
利用input的change事件,借助canvas对图片进行处理(例如压缩),然后ajax发送文件流到后端。
基本原理是通过canvas渲染图片,再通过 toDataURL 方法压缩保存为base64字符串(能够编译为jpg格式的图片)。
后端处理:
后端最终会收到前端发送的base64字符串,接着处理字符串为图片即可。具体请使用关键字base64 转 image 开发语言进行谷歌|百度。前端生成的结果中有一个base64Len,这是字符串的长度,后端应该核对以确认是否提交完整。
1
2
3
|
//php示例:
$img = base64_decode ( $_POST [ 'img' ]);
$img = imagecreatefromstring( $img );
|
以上就是本文的全部内容,希望对大家的学习有所帮助。