批改状态:合格
老师批语:is_scalar()可以判断是否是一个标量,即单值变量, 非标量就是数组或对象, 这个更方便些
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>单个文件上传</title></head><body><form action="uploadFile.php" method="post" enctype="multipart/form-data"><input type="file" name="myFile" /><br/><input type="submit" value="上传文件"/></form></body></html>
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>多个单文件上传</title></head><body><form action="uploadFile.php" method="post" enctype="multipart/form-data"><input type="file" name="myFile[]" /><br/><input type="file" name="myFile[]" /><br/><input type="file" name="myFile[]" /><br/><input type="submit" value="上传文件"/></form></body></html>
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>多文件(批量)上传</title></head><body><form action="uploadFile.php" method="post" enctype="multipart/form-data"><input type="file" name="myFile[]" multiple="multiple"/><br/><input type="submit" value="上传文件"/></form></body></html>
<?phpheader("content-type:text/html;charset=utf-8");require_once 'uploads.php';$files=getFiles();//修改上传目录,如果没有这个文件夹,那么就创建一个$filepath='wang';//修改检查上传的文件是否为真实的图片。true:检查;'false':不要检查上传的文件是否为真实的图片,因为要允许上传除开图片类型外的其他类型文件,如html、txt$flag=false;//修改允许上传文件的类型,为('jpeg','jpg','png','gif','html','txt'),也可以增加新的,如pdf,pptx等等$allowExt=array('jpeg','jpg','png','gif','html','txt');//修改上传大小限制$maxSize=2097152;foreach($files as $fileInfo){ $res=uploadFile($fileInfo,$filepath,$flag,$allowExt,$maxSize);echo $res['mes'],'<br/>';$uploadFiles[]=$res['dest'];//如果要不显示错误信息的话,用@$uploadFiles[]=$res['dest'];}$uploadFiles=array_values(array_filter($uploadFiles));//这样便于保存到数据库print_r($uploadFiles);//打印查看上传保存的结果?>
<?phpheader('Content-Type:text/html;charset=utf-8');//构建上传文件信息function getFiles(){$i=0;foreach($_FILES as $file){//因为这时$_FILES是个三维数组,并且上传单文件或多文件时,数组的第一维的类型不同,这样就可以拿来判断上传的是单文件还是多文件if(is_string($file['name'])){//如果是单文件$files[$i]=$file;$i++;}elseif(is_array($file['name'])){//如果是多文件foreach($file['name'] as $key=>$val){$files[$i]['name']=$file['name'][$key];$files[$i]['type']=$file['type'][$key];$files[$i]['tmp_name']=$file['tmp_name'][$key];$files[$i]['error']=$file['error'][$key];$files[$i]['size']=$file['size'][$key];$i++;}}}return $files;}//针对于单文件、多个单文件、多文件的上传//默认允许上传的文件只为图片类型,并且只有这些图片类型:$allowExt=array('jpeg','jpg','png','gif');并且检查上传的文件是否为真实的图片$flag=true//默认上传保存的文件夹为本地的'uploads'文件夹,允许上传文件的大小最大为2Mfunction uploadFile($fileInfo,$path='./uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize=2097152){//判断错误号if($fileInfo['error']===UPLOAD_ERR_OK){//检测上传文件的大小if($fileInfo['size']>$maxSize){$res['mes']=$fileInfo['name'].'上传文件过大';}$ext=getExt($fileInfo['name']);//检测上传文件的文件类型if(!in_array($ext,$allowExt)){$res['mes']=$fileInfo['name'].'非法文件类型';}//检测是否是真实的图片类型if($flag){if(!getimagesize($fileInfo['tmp_name'])){$res['mes']=$fileInfo['name'].'不是真实图片类型';}}//检测文件是否是通过HTTP POST上传上来的if(!is_uploaded_file($fileInfo['tmp_name'])){$res['mes']=$fileInfo['name'].'文件不是通过HTTP POST方式上传上来的';}if( $res ) return $res; //如果要不显示错误信息的话,用if( @$res ) return $res;//$path='./uploads';//如果没有这个文件夹,那么就创建一if(!file_exists($path)){mkdir($path,0777,true);chmod($path,0777);}//新文件名唯一$uniName=getUniName();$destination=$path.'/'.$uniName.'.'.$ext;//@符号是为了不让客户看到错误信,也可以删除if(!@move_uploaded_file($fileInfo['tmp_name'],$destination)){$res['mes']=$fileInfo['name'].'文件移动失败';}$res['mes']=$fileInfo['name'].'上传成功';$res['dest']=$destination;return $res;}else{//匹配错误信息//注意!错误信息没有5switch($fileInfo['error']){case 1:$res['mes'] = '上传文件超过了PHP配置文件中upload_max_filesize选项的值';break;case 2:$res['mes'] = '超过了HTML表单MAX_FILE_SIZE限制的大小';break;case 3:$res['mes'] = '文件部分被上传';break;case 4:$res['mes'] = '没有选择上传文件';break;case 6:$res['mes'] = '没有找到临时目录';break;case 7:$res['mes'] = '文件写入失败';break;case 8:$res['mes'] = '上传的文件被PHP扩展程序中断';break;}return $res;}}//得到文件扩展名function getExt($filename){return strtolower(pathinfo($filename,PATHINFO_EXTENSION));}//产生唯一字符串function getUniName(){return md5(uniqid(microtime(true),true));}?>
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号