免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1872 | 回复: 1
打印 上一主题 下一主题

php批量上传 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-03-11 18:41 |只看该作者 |倒序浏览
php批量上传








代码:
  1.    <form method="post" action="upload.php" enctype="multipart/form-data">



  2.      <table border=0 cellspacing=0 cellpadding=0 align=center width="100%">



  3.       <tr>



  4.         <td width=55 height=20 align="center"><input type="hidden" name="MAX_FILE_SIZE" value="2000000">文件: </TD>



  5.         <td height="16">



  6.         <input name="file" type="file"  value="浏览" >



  7.          



  8.         < input type="submit" value="上传" name="B1">



  9.         </td>



  10.       </tr>



  11.      </table>



  12.      </form>
复制代码
这里有几个要注意的地方,首先看这句<form method="post" action="upload.php" enctype="multipart/form-data">,这里我们采用POST方法,个别浏览器还支持PUT方法,当然这需要对脚本进行修改,我并不建议这么做。表单中必须设置enctype="multipart/form-data,这样,服务器就知道上传文件带有常规表单信息,记住,这个是必须设置的。此外还需要一个隐藏域来限制上传文件的最大长度:<input type="hidden" name="MAX_FILE_SIZE" value="2000000">,这里name必须设置成MAX_FILE_SIZE,其值就是上传文件的最大长度,单位是B,这里我限制成2M。再看这句:<input name="file" type="file"  value="浏览" >,type="file"说明了文件类型,这样一个基本的上传文件接口就完成了,接下来讲讲如何用PHP来处理上传的文件,此外你的php.ini中设置的上传文件最大长度可能会影响到你的实际上传,请根据实际情况修改,另PHP的上传是先传到临时目录,在移至指定目录的,了;临时目录的可根据需要修改,也可使用默认值。
   好的,表单提交upload.php,来看看这个页面都有什么:
复制PHP内容到剪贴板
PHP代码:
  1. <?php



  2.    $uploaddir = "./files/";//设置文件保存目录 注意包含/   
  3.    $type=array("jpg","gif","bmp","jpeg","png");//设置允许上传文件的类型
  4.    $patch="http://127.0.0.1/cr_downloadphp/upload/files/";//程序所在路径
  5.    
  6.    //获取文件后缀名函数
  7.       function fileext($filename)
  8.     {
  9.         return substr(strrchr($filename, '.'), 1);
  10.     }
  11.    //生成随机文件名函数   
  12.     function random($length)
  13.     {
  14.         $hash = 'CR-';
  15.         $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';
  16.         $max = strlen($chars) - 1;
  17.         mt_srand((double)microtime() * 1000000);
  18.             for($i = 0; $i < $length; $i++)
  19.             {
  20.                 $hash .= $chars[mt_rand(0, $max)];
  21.             }
  22.         return $hash;
  23.     }

  24.    $a=strtolower(fileext($_FILES['file']['name']));
  25.    //判断文件类型
  26.    if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))
  27.      {
  28.         $text=implode(",",$type);
  29.         echo "您只能上传以下类型文件: ",$text,"<br>";
  30.      }
  31.    //生成目标文件的文件名   
  32.    else{
  33.     $filename=explode(".",$_FILES['file']['name']);
  34.         do
  35.         {
  36.             $filename[0]=random(10); //设置随机数长度
  37.             $name=implode(".",$filename);
  38.             //$name1=$name.".Mcncc";
  39.             $uploadfile=$uploaddir.$name;
  40.         }

  41. //   while(file_exists($uploadfile));
  42.      if(is_uploaded_file($_FILES['file']['tmp_name'])){

  43.        if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile)){
  44.             
  45.             
  46.                 //输出图片预览
  47.                 echo "<center>您的文件已经上传完毕 上传图片预览: </center><br><center><img src='$uploadfile'></center>";
  48.                 echo"<br><center><a href='javascript:history.go(-1)'>继续上传</a></center>";
  49.               }
  50.               else{
  51.                 echo "上传失败!";
  52.               }
  53.         }
  54.    }

  55. ?>
复制代码
刚看这些你可能有点晕~~,不过不要紧,听我讲完,你就会发现其实这玩意SO EASY!!首先我讲下原理,该程序以上传图片为例,先判断文件类型是否为图片格式,若是则上传文件,以随机数和时间的组合重新命名文件(避免上传文件重名,这样做很有必要!),接着上传文件到指定目录,成功上传则输出上传的图片预览。这里要对程序中一些函数作些解释。先看return substr(strrchr($filename, '.'), 1), strrchar()函数有什么作用呢,我举个例子大家就知道,比如一个图片文件 pic.jpg,我们用 strrchr处理,strrchr(pic.jpg,'.'),它将返回.jpg,明白了吗?该函数返回指定字符在该字符串最后出现的位置后的字符。配合 substr() 我们就可以取到jpg,这样我们就得到了文件的后缀名,来判断上传文件是否符合指定格式。本程序把指定的格式放在一个数组中,实际使用时可根据需要添加。
    接下来看产生随机数文件名部分,我们看到mt_srand()这个函数,手册上叫他“播下一个更好的随机数发生器种子”,其实就是初始化一个随机数的函数,参数是(double)microtime() * 1000000,这里如果不这是参数就会自动设置个随机数,当然这不符合我们的需要,如此一来,随机数就具备一定的长度,保证了上传文件不重名。接着,我们调用判断文件类型的函数,并将其转化为小写strtolower(fileext($_FILES['file']['name'])),这里有个很关键的东东$_FILES ,这是个超级全局数组,保存了需要处理的表单数据,如果开启了register_globals,也可以直接访问,但这是不安全的。看刚才那个上传接口<input name="file" type="file"  value="浏览" >,根据这个表单名称,我们可以得到很多信息:
    $_FILES['file']['name']--  得到文件名称
    $_FILES['file']['tmp_name']--得到临时存储位置
    $_FILES['file']['size']--得到文件大小
    $_FILES['file']['type']--得到文件MIME类型
得到这些信息,我们就可以轻松判断文件的信息了,是不是很方便?^_^,接下来还有一些函数需要了解,file_exists()--判断指定目录是否存在,不存在我们当然不能上传(好像是废话!),move_uploaded_file--将上传文件移至指定目录,is_uploaded_file--判断文件是否已经通过HTTP POST上传。成功上传,我们就输出预览,否则输出上传失败!大功告成

论坛徽章:
0
2 [报告]
发表于 2012-03-11 20:57 |只看该作者
谢谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP