博客列表 >文件上传(单文件、多个单文件、多文件)

文件上传(单文件、多个单文件、多文件)

王珂
王珂原创
2020年05月12日 17:03:10656浏览

文件上传

单个文件上传

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>单个文件上传</title>
  6. </head>
  7. <body>
  8. <form action="uploadFile.php" method="post" enctype="multipart/form-data">
  9. <input type="file" name="myFile" /><br/>
  10. <input type="submit" value="上传文件"/>
  11. </form>
  12. </body>
  13. </html>

多个单文件上传

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>多个单文件上传</title>
  6. </head>
  7. <body>
  8. <form action="uploadFile.php" method="post" enctype="multipart/form-data">
  9. <input type="file" name="myFile[]" /><br/>
  10. <input type="file" name="myFile[]" /><br/>
  11. <input type="file" name="myFile[]" /><br/>
  12. <input type="submit" value="上传文件"/>
  13. </form>
  14. </body>
  15. </html>

多文件(批量)上传

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>多文件(批量)上传</title>
  6. </head>
  7. <body>
  8. <form action="uploadFile.php" method="post" enctype="multipart/form-data">
  9. <input type="file" name="myFile[]" multiple="multiple"/><br/>
  10. <input type="submit" value="上传文件"/>
  11. </form>
  12. </body>
  13. </html>

uploadFile.php用于设置上传目录、文件类型、大小限制

  1. <?php
  2. header("content-type:text/html;charset=utf-8");
  3. require_once 'uploads.php';
  4. $files=getFiles();
  5. //修改上传目录,如果没有这个文件夹,那么就创建一个
  6. $filepath='wang';
  7. //修改检查上传的文件是否为真实的图片。true:检查;'false':不要检查上传的文件是否为真实的图片,因为要允许上传除开图片类型外的其他类型文件,如html、txt
  8. $flag=false;
  9. //修改允许上传文件的类型,为('jpeg','jpg','png','gif','html','txt'),也可以增加新的,如pdf,pptx等等
  10. $allowExt=array('jpeg','jpg','png','gif','html','txt');
  11. //修改上传大小限制
  12. $maxSize=2097152;
  13. foreach($files as $fileInfo){ $res=uploadFile($fileInfo,$filepath,$flag,$allowExt,$maxSize);
  14. echo $res['mes'],'<br/>';
  15. $uploadFiles[]=$res['dest'];//如果要不显示错误信息的话,用@$uploadFiles[]=$res['dest'];
  16. }
  17. $uploadFiles=array_values(array_filter($uploadFiles));//这样便于保存到数据库
  18. print_r($uploadFiles);//打印查看上传保存的结果
  19. ?>

Uploads.php

  1. <?php
  2. header('Content-Type:text/html;charset=utf-8');
  3. //构建上传文件信息
  4. function getFiles(){
  5. $i=0;
  6. foreach($_FILES as $file){
  7. //因为这时$_FILES是个三维数组,并且上传单文件或多文件时,数组的第一维的类型不同,这样就可以拿来判断上传的是单文件还是多文件
  8. if(is_string($file['name'])){
  9. //如果是单文件
  10. $files[$i]=$file;
  11. $i++;
  12. }elseif(is_array($file['name'])){
  13. //如果是多文件
  14. foreach($file['name'] as $key=>$val){
  15. $files[$i]['name']=$file['name'][$key];
  16. $files[$i]['type']=$file['type'][$key];
  17. $files[$i]['tmp_name']=$file['tmp_name'][$key];
  18. $files[$i]['error']=$file['error'][$key];
  19. $files[$i]['size']=$file['size'][$key];
  20. $i++;
  21. }
  22. }
  23. }
  24. return $files;
  25. }
  26. //针对于单文件、多个单文件、多文件的上传
  27. //默认允许上传的文件只为图片类型,并且只有这些图片类型:$allowExt=array('jpeg','jpg','png','gif');并且检查上传的文件是否为真实的图片$flag=true
  28. //默认上传保存的文件夹为本地的'uploads'文件夹,允许上传文件的大小最大为2M
  29. function uploadFile($fileInfo,$path='./uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize=2097152){
  30. //判断错误号
  31. if($fileInfo['error']===UPLOAD_ERR_OK){
  32. //检测上传文件的大小
  33. if($fileInfo['size']>$maxSize){
  34. $res['mes']=$fileInfo['name'].'上传文件过大';
  35. }
  36. $ext=getExt($fileInfo['name']);
  37. //检测上传文件的文件类型
  38. if(!in_array($ext,$allowExt)){
  39. $res['mes']=$fileInfo['name'].'非法文件类型';
  40. }
  41. //检测是否是真实的图片类型
  42. if($flag){
  43. if(!getimagesize($fileInfo['tmp_name'])){
  44. $res['mes']=$fileInfo['name'].'不是真实图片类型';
  45. }
  46. }
  47. //检测文件是否是通过HTTP POST上传上来的
  48. if(!is_uploaded_file($fileInfo['tmp_name'])){
  49. $res['mes']=$fileInfo['name'].'文件不是通过HTTP POST方式上传上来的';
  50. }
  51. if( $res ) return $res; //如果要不显示错误信息的话,用if( @$res ) return $res;
  52. //$path='./uploads';
  53. //如果没有这个文件夹,那么就创建一
  54. if(!file_exists($path)){
  55. mkdir($path,0777,true);
  56. chmod($path,0777);
  57. }
  58. //新文件名唯一
  59. $uniName=getUniName();
  60. $destination=$path.'/'.$uniName.'.'.$ext;
  61. //@符号是为了不让客户看到错误信,也可以删除
  62. if(!@move_uploaded_file($fileInfo['tmp_name'],$destination)){
  63. $res['mes']=$fileInfo['name'].'文件移动失败';
  64. }
  65. $res['mes']=$fileInfo['name'].'上传成功';
  66. $res['dest']=$destination;
  67. return $res;
  68. }else{
  69. //匹配错误信息
  70. //注意!错误信息没有5
  71. switch($fileInfo['error']){
  72. case 1:
  73. $res['mes'] = '上传文件超过了PHP配置文件中upload_max_filesize选项的值';
  74. break;
  75. case 2:
  76. $res['mes'] = '超过了HTML表单MAX_FILE_SIZE限制的大小';
  77. break;
  78. case 3:
  79. $res['mes'] = '文件部分被上传';
  80. break;
  81. case 4:
  82. $res['mes'] = '没有选择上传文件';
  83. break;
  84. case 6:
  85. $res['mes'] = '没有找到临时目录';
  86. break;
  87. case 7:
  88. $res['mes'] = '文件写入失败';
  89. break;
  90. case 8:
  91. $res['mes'] = '上传的文件被PHP扩展程序中断';
  92. break;
  93. }
  94. return $res;
  95. }
  96. }
  97. //得到文件扩展名
  98. function getExt($filename){
  99. return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
  100. }
  101. //产生唯一字符串
  102. function getUniName(){
  103. return md5(uniqid(microtime(true),true));
  104. }
  105. ?>
声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议