本文实例讲述了PHP实现多文件上传的方法。分享给大家供大家参考。具体实现方法如下:
<?php
define('ROOT','D:/Program Files/www/test/');
class Files_Tool{
protected static $allowExt=array('.jpg','.jpeg','.png','.gif','.bmp','.svg','.chm','.pdf','.zip','.rar','.tar','.gz','.bzip2','.ppt','.doc');
public static $wrong=array();
public static $path=array();
protected static $error=array(
0=>'文件上传失败,没有错误发生,文件上传成功',
1=>'文件上传失败,上传的文件超过了 php.ini中upload_max_filesize 选项限制的值',
2=>'文件上传失败,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值',
3=>'文件上传失败,文件只有部分被上传',
4=>'文件上传失败,没有文件被上传',
5=>'文件上传失败,未允许的后缀',
6=>'文件上传失败,找不到临时文件夹.PHP 4.3.10 和 PHP 5.0.3 引进',
7=>'文件上传失败,文件写入失败.PHP 5.1.0 引进',
8=>'文件上传失败,未接收到表单域的NAME',
9=>'文件上传失败,,错误未知'
);
public static function upload($name){
//检测是否接收到表单域的NAME
if(!isset($_FILES[$name])){
self::$wrong[]=8;
return false;
}
//3维数组简化成2维数组
$files=array_shift($_FILES);
//获取后缀
$files=self::get_Ext($files);
//处理文件次数
$n=count($files['name']);
for($i=0;$i<$n;$i++){
//查看当前文件是否有错误信息,有则跳过当前文件,处理下个文件
if($files['error'][$i]!=0){
self::$wrong[$i+1]=$files['error'][$i];
continue;
}
//查看当前文件的后缀,是否允许,如果不允许,跳过当前文件
if(!in_array($files['name'][$i],self::$allowExt)){
self::$wrong[$i+1]=5;
continue;
}
//路径
$dir=self::time_Dir();
//文件名
$name=self::rand_Name();
//后缀
$ext=$files['name'][$i];
//文件位置
$path=$dir.$name.$ext;
//移动临时文件,如果失败,跳过当前文件
if(!move_uploaded_file($files['tmp_name'][$i],$path)){
self::$wrong[$i]=9;
continue;
}
//存入路径
self::$path[$i+1]=strtr($path,array(ROOT=>''));
}
return self::$path;
}
//获取后缀的方法
protected static function get_Ext($arr){
if(!is_array($arr) || !isset($arr['name'])){return false;}
foreach($arr['name'] as $k=>$v){
$arr['name'][$k]=strtolower(strrchr($v,'.'));
}
return $arr;
}
//以日期生成路径
protected static function time_Dir(){
$dir=ROOT.'Data/images/'.date('Y/m/d/',time());
if(!is_dir($dir)){
mkdir($dir,0777,true);
}
return $dir;
}
//生成随机文件名
protected static function rand_Name(){
$str=str_shuffle('1234567890qwertyuiopasdfghjklzxcvbnm');
$str=substr($str,0,6);
return $str;
}
//错误接口
public static function errors(){
foreach(self::$wrong as $k=>$v){
self::$wrong[$k]='第'.$k.'个'.self::$error[$k];
}
return self::$wrong;
}
}
希望本文所述对大家的php程序设计有所帮助。
标签:
PHP,多文件,上传
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
桃源资源网 Design By www.nqtax.com
暂无“PHP实现多文件上传的方法”评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。