require_once(dirname(__file__)."/lwgdb.inc.php");//数据库连接与查询类 require_once(dirname(__file__)."/lwgupload.inc.php");//父类 class lwguploadandquery extends lwgupload{ var $sql;//sql语句 var $url;//文件上传成功后转向的url
//重要提示:sql语句写法: //$sql=sprintf("update test1 set name='%s', image1='%s', image2='%s' where id='%d'",$_post['name'],"image1_name","image2_name",$_post['id']); //"image1_name","image2_name"中,image1和image2是文件域的name或id,后面加了"_name"后缀,便于下面找到它并修改它 function lwguploadandquery($sql="",$uploadfield="",$url="",$uploadpath="",$maxsize="",$ftype="all"){ $this->sql=$sql; $this->url=$url; $this->lwgupload($uploadfield,$uploadpath,$maxsize,$ftype); }
function run(){ if (empty($this->sql))return $this->output("没有可执行的sql语句。");
if (!is_array($this->uploadfield))$this->uploadfield=array($this->uploadfield);//如果不为数组改为数组,便于后面代码的简化 if (!is_array($this->maxsize))$this->maxsize=array($this->maxsize);//同上 if (!is_array($this->ftype))$this->ftype=array($this->ftype);//同上
$totaluploadfield=count($this->uploadfield); for ($i=0;$i<$totaluploadfield;$i++){ $uploadfile=$_files[$this->uploadfield[$i]]['tmp_name']; $file_name=$_files[$this->uploadfield[$i]]['name']; $file_old=$_post[$this->uploadfield[$i].'_old'];//用在更新中,表示上传文件所对应的原有文件 $file_del=$_post[$this->uploadfield[$i].'_del'];//原有文件是否标记为删除
if ($uploadfile!=""&&$file_name!=""){ //表示需要上传,即文件域里填入了任何字符 $uploadfield[]=$this->uploadfield[$i]; //取得新的上传字段,因为文件域中没有填入任何字符的不用上传 $maxsize[]=(!empty($this->maxsize[$i]))?$this->maxsize[$i]:$this->maxsize[0]; //取得相对应的大小限制值 $ftype[]=(!empty($this->ftype[$i]))?$this->ftype[$i]:$this->ftype[0]; //取得相对应的类型限制值 $newfile=$this->uploadpath."/".$file_name; //上传后的文件地址 $insertname=$file_name; //修改sql语言时要用到,将mysql表中对应字段的值改为目前上传文件名 if ($file_old!="")$oldfile[]=$this->uploadpath."/".sprintf('%s',$file_old); //用在更新中,取得原有文件地址,当新文件上传后删除旧文件 } else if ($file_old!=""){ //表示不需要上传,即文件域里没有填入任何字符,但是有旧文件 if ($file_del=="true"){ //如果旧文件标记为删除 $insertname=""; //修改sql语言时要用到,将mysql表中对应字段的值改为空 $oldfile[]=$this->uploadpath."/".sprintf('%s',$file_old); } else $insertname=sprintf('%s',$file_old); //既不用上传也不用删除,修改sql语言时要用到,将mysql表中对应字段的值改为原文件名 } else $insertname=""; //既不用上传也没有原文件,修改sql语言时要用到,将mysql表中对应字段的值改为空 $this->sql=str_replace($this->uploadfield[$i]."_name", $insertname, $this->sql); //修改sql语句 }
class lwgupload{ //-------------可以设置值的变量------------------------ var $uploadfield;//上传文件的字段名 var $maxsize;//限制上传文件的大小 var $file_old;//需要删除的旧文件 var $uploadpath;//文件的上传路径 var $ftype;//限制上传文件的类型 var $debug=true;//是否显示调试或错误信息
//------------用来获取值的变量--------------------------- var $uploadfile;//上传后的临时文件 var $file_name;//文件名 var $file_size;//文件的大小 var $file_size_format;//格式化后的$file_size var $file_type;//文件类型 var $debugstr="";//记录调试信息 var $err="";//记录错误信息
//test()用来测试能否全部上传,否则一个也不要上传 //$oldfile表示要删除的文件,用在更新中,删除旧的上传新的 function test($oldfile=''){ if ($this->uploadfield=="")return; if (empty($this->uploadpath))$this->uploadpath=dirname($_server['path_translated'])."/upload"; if (empty($this->maxsize))$this->maxsize=1048576; if (!is_array($this->uploadfield))$this->uploadfield=array($this->uploadfield); //如果不为数组改为数组,便于后面代码的简化 $total_upload=count($this->uploadfield);//获得总字段数
if (!is_array($this->maxsize))$this->maxsize=array($this->maxsize);//如果不为数组改为数组,便于后面代码的简化 if (!is_array($this->ftype))$this->ftype=array($this->ftype);//同上
//如果没有相应路径则建立之 if (!file_exists($this->uploadpath)){ if (!mkdir($this->uploadpath,0700))return output("错误!请手动建立有效路径。"); }
//测试过关后可以上传 function upload(){ if ($this->uploadfield=="")return false; $total_upload=count($this->uploadfield);
for ($i=0;$i<$total_upload;$i++){ $this->file_size_format[$i]=$this->format_maxsize($this->file_size[$i]);
if (@move_uploaded_file($this->uploadfile[$i],$this->newfile[$i])) $this->debugstr.="文件'".$this->file_name[$i]."'(".$this->file_size_format[$i].")上传成功。<br>"; else { if ($i>0)$this->err_del(($i-1),$this->newfile); //如果有一个上传失败,则删除所有已上传的文件 return $this->output("对不起!文件'".$this->file_name[$i]."'上传失败。请重试。"); } } return true; }
//格式化文件大小数字 function format_maxsize($value){ if ($value<1024)$maxsize_value = $value."字节"; elseif ($value<1024*1024)$maxsize_value = number_format((double)($value/1024),2)."kb"; else $maxsize_value = number_format((double)($value/(1024*1024)),2)."mb"; return $maxsize_value; }
//出错后删除已上传的文件 function err_del($i,$thefile){ while ($i>=0){ if (@unlink($thefile[$i])!=false)$this->debugstr.="文件'".$thefile[$i]."'删除成功 <br>"; $i--; } }
//记录和输出错误信息 function output($msg){ if ($msg!="")$this->err=$msg; if ($this->debug)echo "<script language=/"javascript/" type=/"text/javascript/">alert(/"".$msg."/");history.go(-1)</script>"; return false; } }
/* ----------------使用方法----------------------------------------------- $obj=lwgupload("image1","",1024*2,"all"); if ($obj->test())$obj->upload(); ------------------------------------------------------------------------- */ ?>