php文件上传类
你好,要先建立一个html代码
<formaction="upload_file.php"method="post"
enctype="multipart/form-data">
<labelfor="file">Filename:</label>
<inputtype="file"name="file"id="file"/>
<br/>
<inputtype="submit"name="submit"value="Submit"/>
</form>
然后创建upload_file文件用$_FILE判断文件,下面是判断文件的具体信息
$_FILES["file"]["name"] - 被上传文件的名称
$_FILES["file"]["type"] - 被上传文件的类型
$_FILES["file"]["size"] - 被上传文件的大小,以字节计
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称
$_FILES["file"]["error"] - 由文件上传导致的错误代
希望对你有帮助!
B. php 上传文件类
<?php
/*
* -------------------------------------------------
* @file : File.class.php
* @function : 文件相关的类
* @link : 星模PHP培训 www.xingmo.com
* @right : 2002-2009 Xingmo Inc
* @author : Kuai Yigang <KuaiYigang#xingmo.com>
* @date : 2005-3-25
* @update : 2010/1/30
* -------------------------------------------------
*/
class Files
{
/**
* 将上传文件转移到指定位置
*
* @param string $file_name
* @param string $target_name
* @return blog
*/
public function move_uploaded_file($file_name, $target_name = '')
{
if (function_exists("move_uploaded_file"))
{
if (move_uploaded_file($file_name, $target_name))
{
return true;
}
else
{
if (($file_name, $target_name))
{
return true;
}
else
{
return false;
}
}
}
else
{
if (($file_name, $target_name))
{
return true;
}
else
{
return false;
}
}
return false;
}
/******************************************
*函数:upload($fileArray,$uploaddir,$filename)
*作用:上传文件函数
*输入:$_FILES['userfile'],$uploaddir,$filename(不带后缀)
*输出:$fullname(整个文件名)
**
******************************************
*--制作--日期--
*[email protected] 2004-06-22 23:00
******************************************
*--修改--日期--目的--
*
*/
//有待修改,加上
public function upload($fileArray, $uploaddir, $filename)
{
//取得文件后缀
$suffix = $this->getExt($fileArray['name']);
//文件及路径
if(!file_exists($uploaddir))
{
$this->mkdirAll($uploaddir,0777);
}
//chmod($uploaddir,0777);
$fullname = $filename.".".$suffix;
$uploadfile = $uploaddir.'/'.$fullname;
if($this->move_uploaded_file($fileArray['tmp_name'], $uploadfile))
{
return $fullname;
}
else
{
return false;
}
}
/******************************************
*函数:getExt($file)
*作用:取得文件后缀
*输入:文件名,$_FILES['userfile']['name']
*输出:$ext(文件后缀)
**
******************************************
*--制作--日期--
*[email protected] 2004-12-19 14:08
******************************************
*--修改--日期--目的--
*
*/
public function getExt($file, $type=1)
{
if($type == 1)
{
$temp = explode('.', $file);
$ext = strtolower(array_pop($temp));//strtolower()转换成小写字符串 array_pop()将数组最后一个单元弹出
}
else if($type==2)
{
$ext = strtolower(end(explode('.', $file)));
}
else if($type==3)
{
$ext = strtolower(pathinfo($file, PATHINFO_EXTENSION));
}
else
{
$ext = strtolower(substr($file, strrpos($file, '.')+1));
}
return $ext;
//如果是图片,可以用getimagesize()
}
/******************************************
*函数:mkdirAll($filepath)
*作用:检查是否存在一个目录,如果不存在则创建之
*输入:$filepath(目录路径,如$UPLOAD.'/1/2/3/4')
*输出:true OR false
**
******************************************
*--制作--日期--
*[email protected] 2005-5-23
******************************************
*--修改--日期--目的--
*
*/
public function mkdirAll($filepath)
{
$temp = explode('/', $filepath);
$path = $temp[0].'/';
for($i=1; $i<count($temp); $i++)//count计算数组中的单元数目或对象中的属性个数
{
$path .= $temp[$i].'/';
if(!file_exists($path))//file_exists()检查文件和目录是否存在,存在返回true
{
mkdir($path, 0777);
chmod($path, 0777);//chmod改变文件模式
}
}
return (file_exists($filepath)) ? true : false;
}
/******************************************
*函数:checkPhoto
*作用:检查是否可以上传上的图片
*输入:$fileArray:$_FILES['file']
*输出:true OR false
**
******************************************
*--制作--日期--
*[email protected] 2005-5-30
******************************************
*--修改--日期--目的--
*
*/
public function checkPhoto($fileArray)
{
return (strtolower($this->getExt($fileArray['name'])) == 'jpg' || strtolower($this->getExt($fileArray['name'])) == 'jpeg' || strtolower($this->getExt($fileArray['name'])) == 'gif' || strtolower($this->getExt($fileArray['name'])) == 'png') ? true :false;
}
/******************************************
*函数:checkFlash
*作用:检查是否可以上传的flash
*输入:$fileArray:$_FILES['file']
*输出:true OR false
**
******************************************
*--制作--日期--
*[email protected] 2005-6-2
******************************************
*--修改--日期--目的--
*
*/
public function checkFlash($fileArray)
{
return (strtolower($this->getExt($fileArray['name'])) == 'swf') ? true :false;
}
/******************************************
*函数:uploadPhoto
*作用:上传图片(限制了上传时文件的大小及上传后存在服务器上的文件大小,上传后存在一个临时目录)
*输入:$fileArray:$_FILES['file'],$TempDir:上传后存放的临时目录,$filename:上传后存放在服务器上的文件名(不带后缀),$MaxUpload:最大可上传的文件大小,$MaxSave:最大在服务器上存放的大小
*输出:'true|文件名' OR 'false'
**
******************************************
*--制作--日期--
*[email protected] 2006-4-21
******************************************
*--修改--日期--目的--
*
*/
//俱乐部中使用
public function uploadPhoto($fileArray, $TempDir, $filename, $MaxUpload, $MaxSave, $SmallWidth, $SmallHeight)
{
require 'Image.class.php';
$Image = new Image;
if($fileArray['error'] == 1)
{
return 'false|上传的文件过大';
}
elseif($fileArray['error'] == 0)
{
//return 'false|上传的文件过大';
}
else
{
return 'false|上传失败';
}
if($fileArray['size'] <= $MaxSave)
{
$fullname = $this->upload($fileArray,$TempDir,$filename);
if($fullname)
{
$SmallPicName = $this->getSmallPicName($fullname, $SmallWidth, $SmallHeight);//小图片的高、宽
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$SmallPicName, $SmallWidth, $SmallHeight);
return 'true|'.$fullname.'|'.$SmallPicName;
}
else
{
return 'false|上传失败';
}
}
if(($fileArray['size'] > $MaxSave) && (filesize($fileArray['tmp_name']) <= $MaxUpload))
{
$fullname = $this->upload($fileArray,$TempDir,$filename);
if($fullname)
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '1024', '768');
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$SmallPicName = $this->getSmallPicName($fullname, $SmallWidth, $SmallHeight);//小图片的高、宽
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$SmallPicName, $SmallWidth, $SmallHeight);
return 'true|'.$fullname.'|'.$SmallPicName;
}
else
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '800', '600');
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$SmallPicName = $this->getSmallPicName($fullname, $SmallWidth, $SmallHeight);//小图片的高、宽
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$SmallPicName, $SmallWidth, $SmallHeight);
return 'true|'.$fullname.'|'.$SmallPicName;
}
else
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '600', '480');
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$SmallPicName = $this->getSmallPicName($fullname, $SmallWidth, $SmallHeight);//小图片的高、宽
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$SmallPicName, $SmallWidth, $SmallHeight);
return 'true|'.$fullname.'|'.$SmallPicName;
}
else
{
return 'false|上传的文件过大';
}
}
}
}
else
{
return 'false|上传失败';
}
}
if($fileArray['size'] > $MaxUpload)
{
return 'false|上传的文件过大';
}
}
//某社区中使用
public function uploadPhoto2($fileArray, $TempDir, $filename, $MaxUpload, $MaxSave)
{
require_once 'Image.class.php';
$Image = new Image;
$Photo = array();
if($fileArray['error'] == 1)
{
return false;
}
elseif($fileArray['error'] == 0)
{
}
else
{
return false;
}
if($fileArray['size'] <= $MaxSave)
{
$fullname = $this->upload($fileArray,$TempDir,$filename);
$Exif = new Exif($TempDir.'/'.$fullname);//2006-8-8增加
$Photo[0] = $Exif->getImageInfo();//2006-8-8增加
if($fullname)
{
$Photo[1] = $fullname;//2006-8-8增加
$Photo = serialize($Photo);//2006-8-8增加
return $Photo;//2006-8-8修改
}
else
{
return false;
}
}
if(($fileArray['size'] > $MaxSave) && (filesize($fileArray['tmp_name']) <= $MaxUpload))
{
$fullname = $this->upload($fileArray,$TempDir,$filename);
$Exif = new Exif($TempDir.'/'.$fullname);//2006-8-8增加
$Photo[0] = $Exif->getImageInfo();//2006-8-8增加
if($fullname)
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '1024', '768');
clearstatcache();
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$Photo[1] = $fullname;//2006-8-8增加
$Photo = serialize($Photo);//2006-8-8增加
return $Photo;//2006-8-8修改
}
else
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '800', '600');
clearstatcache();
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$Photo['FullName'] = $fullname;//2006-8-8增加
$Photo = serialize($Photo);//2006-8-8增加
return $Photo;//2006-8-8修改
}
else
{
$Image->Resize($TempDir.'/'.$fullname, $TempDir.'/'.$fullname, '600', '480');
clearstatcache();
if(filesize($TempDir.'/'.$fullname) <= $MaxSave)
{
$Photo[1] = $fullname;//2006-8-8增加
$Photo = serialize($Photo);//2006-8-8增加
return $Photo;//2006-8-8修改
}
else
{
return false;
}
}
}
}
else
{
return false;
}
}
if($fileArray['size'] > $MaxUpload)
{
return false;
}
}
//得到缩小后的图片的名称,比如原文件是123.gif,缩小到100*50后的文件名是123_100_50.gif
public function getSmallPicName($filename, $width, $height)
{
$full_length = strlen($filename);
$type_length = strlen($this->getExt($filename));
$name_length = $full_length-$type_length;
$name = substr($filename,0,$name_length-1);
return $name."_".$width."_".$height.".".$this->getExt($filename);
}
//下载文件,$FilePath:文件路径,$FileName:文件名称
public function download($FilePath, $FileName, $type=1)
{
if($type == 1)
{
header("Pragma: public");
header("Expires: 0");
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Type: application/force-download");
header( "Content-Disposition: attachment; filename=".$FileName);
header( "Content-Description: File Transfer");
@readfile($FilePath);
}
if($type == 2)
{
$filesize = filesize($FilePath);
$imagesize = getimagesize($FilePath);
$filetype = $imagesize['mime'];
ob_end_clean();
header('Cache-control: max-age=31536000');
header('Expires: '.gmdate('D, d M Y H:i:s', time() + 31536000).' GMT');
header('Content-Encoding: none');
header('Content-Disposition: attachment; filename='.$FileName);
header('Content-Type: '.$filetype);
@$fp = fopen($FilePath, 'rb');
@flock($fp, 2);
$file = @fread($fp, $filesize);
@fclose($fp);
echo $file;
}
}
//查看图片,$FilePath:文件路径
public function displayPic($FilePath, $type=2)
{
if($type == 1)
{
$imagesize = getimagesize($FilePath);
$filetype = $imagesize['mime'];
header('Content-Type: '.$filetype);
$pic = file_get_contents($FilePath);
echo $pic;
flush();
}
if($type == 2)
{
$imagesize = getimagesize($FilePath);
$filetype = $imagesize['mime'];
$filesize = filesize($FilePath);
//ob_end_clean();
//header('Cache-control: max-age=31536000');
//header('Expires: '.gmdate('D, d M Y H:i:s', time() + 31536000).' GMT');
//header('Content-Encoding: none');
//header('Content-Disposition: attachment; filename='.$attach['filename']);
header('Content-Type: '.$filetype);
@$fp = fopen($FilePath, 'rb');
@flock($fp, 2);
$pic = @fread($fp, $filesize);
@fclose($fp);
echo $pic;
}
}
//下载网络上的文件,保存在本地
//从远端取得文件,保存在本地硬盘c:目录下
//curl_download("http://www.xingmo.com.cn/logo.gif", "20090831.gif");
function curl_download($remote, $local)
{
$cp = curl_init($remote);
$fp = fopen($local, "w");
//curl_setopt($cp, CURLOPT_URL, $remote);
curl_setopt($cp, CURLOPT_FILE, $fp); //设置了curl要写入的本地文件
//curl_setopt($cp, CURLOPT_HEADER, false); //不输出head信息
curl_exec($cp);
curl_close($cp);
fclose($fp);
}
}
?>
C. 怎么将php文件上传到服务器上
创建一个文件上传表单
允许用户从表单上传文件是非常有用的。
请看下面这个供上传文件的 HTML 表单:
<html>
<body>
<form action="upload_file.php" method="post"
enctype="multipart/form-data">
<label for="file">Filename:</label>
<input type="file" name="file" id="file" />
<br />
<input type="submit" name="submit" value="Submit" />
</form>
</body>
</html>
请留意如下有关此表单的信息:
<form> 标签的 enctype 属性规定了在提交表单时要使用哪种内容类型。在表单需要二进制数据时,比如文件内容,请使用 "multipart/form-data"。
<input> 标签的 type="file" 属性规定了应该把输入作为文件来处理。举例来说,当在浏览器中预览时,会看到输入框旁边有一个浏览按钮。
注释:允许用户上传文件是一个巨大的安全风险。请仅仅允许可信的用户执行文件上传操作。
创建上传脚本
"upload_file.php" 文件含有供上传文件的代码:
<?php
if ($_FILES["file"]["error"] > 0)
{
echo "Error: " . $_FILES["file"]["error"] . "<br />";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
echo "Stored in: " . $_FILES["file"]["tmp_name"];
}
?>
通过使用 PHP 的全局数组 $_FILES,你可以从客户计算机向远程服务器上传文件。
第一个参数是表单的 input name,第二个下标可以是 "name", "type", "size", "tmp_name" 或 "error"。就像这样:
$_FILES["file"]["name"] - 被上传文件的名称
$_FILES["file"]["type"] - 被上传文件的类型
$_FILES["file"]["size"] - 被上传文件的大小,以字节计
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称
$_FILES["file"]["error"] - 由文件上传导致的错误代码
这是一种非常简单文件上传方式。基于安全方面的考虑,您应当增加有关什么用户有权上传文件的限制。
上传限制
在这个脚本中,我们增加了对文件上传的限制。用户只能上传 .gif 或 .jpeg 文件,文件大小必须小于 20 kb:
<?php
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000))
{
if ($_FILES["file"]["error"] > 0)
{
echo "Error: " . $_FILES["file"]["error"] . "<br />";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
echo "Stored in: " . $_FILES["file"]["tmp_name"];
}
}
else
{
echo "Invalid file";
}
?>
注释:对于 IE,识别 jpg 文件的类型必须是 pjpeg,对于 FireFox,必须是 jpeg。
保存被上传的文件
上面的例子在服务器的 PHP 临时文件夹创建了一个被上传文件的临时副本。
这个临时的复制文件会在脚本结束时消失。要保存被上传的文件,我们需要把它拷贝到另外的位置:
<?php
if ((($_FILES["file"]["type"] == "image/gif")
|| ($_FILES["file"]["type"] == "image/jpeg")
|| ($_FILES["file"]["type"] == "image/pjpeg"))
&& ($_FILES["file"]["size"] < 20000))
{
if ($_FILES["file"]["error"] > 0)
{
echo "Return Code: " . $_FILES["file"]["error"] . "<br />";
}
else
{
echo "Upload: " . $_FILES["file"]["name"] . "<br />";
echo "Type: " . $_FILES["file"]["type"] . "<br />";
echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";
echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />";
if (file_exists("upload/" . $_FILES["file"]["name"]))
{
echo $_FILES["file"]["name"] . " already exists. ";
}
else
{
move_uploaded_file($_FILES["file"]["tmp_name"],
"upload/" . $_FILES["file"]["name"]);
echo "Stored in: " . "upload/" . $_FILES["file"]["name"];
}
}
}
else
{
echo "Invalid file";
}
?>
上面的脚本检测了是否已存在此文件,如果不存在,则把文件拷贝到指定的文件夹。
D. php文件上传使用了哪些函数
//定义上传目录变量
$upath="./upload/";
//获取上传文件信息
$fupload=$_FILES['image'];
//定义上传的文件类型
$imgtype=array("image/jpeg","image/jpg","image/png","image/gif","image/bmp");
//获取php.ini文件upload_max_filesize的大小
$umfs=ini_get("upload_max_filesize");
//获取html表单post文件大小
$pms=ini_get("post_max_size");
//获取上传文件错误信息
if($fupload["error"]>0){
switch($fupload["error"]){
case 1:
$errmsg="上传的文件的大小超过了".$umfs;
break;
case 2:
$errmsg="上传的文件的大小超过了HTML表单中".$pms."的限制";
break;
case 3:
$errmsg="文件只有部分被上传";
break;
case 4:
$errmsg="没有选择上传文件";
break;
case 6:
$errmsg="找不到临时文件夹";
break;
case 7:
$errmsg="文件写入失败";
break;
}
die("上传错误:".$errmsg);
}
//过滤上传文件的大小
if($fupload["size"]>100000000){
die("上传文件的大小超出了限制");
}
//过滤上传的文件类型
if(!in_array($fupload["type"],$imgtype)){
die("不支持上传的文件类型:".$fupload["type"]);
}
//执行上传文件
if(is_uploaded_file($fupload["tmp_name"])){
if(move_uploaded_file($fupload["tmp_name"],$upath.$fupload["name"])){
echo "文件上传成功!";
}
}else{
die("不是一个上传文件!");
}
E. 如何在php上实现文件上传功能
PHP 一般使用 POST 方法上传文件,下面是一个简单的文件上传示例,里面有相关的注释:
up.htm 文件:
----------
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<title>Up Sample</title>
</head>
<body>
<form action="up.php" method="post" enctype="multipart/form-data">
<!--备注:表单中 enctype="multipart/form-data " 的意思,是设置表单的 MIME 编码。默认情况,这个编码格式是application/x-www-form-urlencoded,不能用于文件上传;只有使用了 multipart/form-data ,才能完整的传递文件数据,进行下面的操作,并且 method 要设置为 "post"-->
File:<br />
<input type="file" name="upfile" size="30"><br />
<!--上传框要设置 type="file"-->
<br />
<input type="submit" value="Upload">
</form>
</body>
</html>
----------
up.php 文件
----------
<?php
if (is_uploaded_file($_FILES["upfile"]["tmp_name"])){
//如果有文件上传
//is_uploaded_file -- 判断文件是否是通过 HTTP POST 上传的,返回布尔值
//$_FILES['upfilename']['...'],其中的 'upfilename' 即为上传框的 name 属性
//$_FILES['upfile']['tmp_name'] -- 文件被上传后在服务端储存的临时文件名,一般是系统默认
if(!eregi('pdf', $_FILES['upfile']['type'])){
//我们这里假设你要上传一个 pdf 文件
//if(!eregi('pdf', $_FILES['upfile']['type'])) 这个是判断上传文件类型的,是不是 pdf 文件,当然,若是想判断是否是 jpg 文件的话,将 pdf 改成 jpg 就可以了,即 if(!eregi('jpg', $_FILES['upfile']['type']))
//$_FILES['upfile']['type'] 是文件的 MIME 类型,如果浏览器提供此信息的话。例如“image/gif”
echo 'The uploaded file is not an pdf File! Please upload a right file!';
}else{
$filename = $_FILES['upfile']['name'];
//$filename = $_FILES['upfile']['name'],这里是指定上传后的文件名,这里使用的仍是原来的文件名字,($_FILES['upfile']['name'] 是原始文件的名字)
if(move_uploaded_file($_FILES["upfile"]["tmp_name"], dirname(__FILE__)."/upload_file/".$filename)){
//这里就是上传文件
//dirname(__FILE__)."/upload_file/".$file_name -- 指定上传的目标文件,假设你要上传的目标文件夹upload_file 是和当前文件(upload.php)在同一文件夹下
//chmod(dirname(__FILE__)."/upload_file/". $file_name, 0444);
//上面注释掉的是用来改变上传后文件的属性,444 即只有执行和读的权限(看情况加上)
echo $_FILES["upfile"]["name"] . " uploaded succeed!!!";
}else{
echo "Can't upload!!!";
}
}
}else{
echo "File is not selected";
}
//需要注意的:
/*
在你的 up.php 同级目录下建立 upload_file 文件夹,来存放上传的文件
在上传之前要看一下 php 的配置文件:php.ini 中的三处设置
1.是否允许文件上传:( file_uploads = On )
2.文件上传的最大 size:( upload_max_filesize )
3.post 的最大 size ( post_max_size ) 这个大小设置成和 uplod_max_filesize 一样大或比 uplod_max_filesize 大
*/
/*
这只是很简单的一个文件上传的例子,为了帮助理解,只是判断了一下上传文件的类型,还可以使用 if 语句来判断上传文件的大小($_FILES['upfile']['type'])),并进行提示控制等,相关可以查阅 $_FILE['upfile'] 数组的各个值分别代表什么
*/
?>
F. PHP文件上传类型限制
有两种方式可以给你解决,也可以几种方式同时使用
使用原本自带的函数getimagesize来判断是否是图片
使用获取上传文件头的方式来判断
$filename='xxxx.gif';
$file=fopen($filename,'rb');
$bin=fread($file,2);//只读取上传文件的头文信息的2个字节
fclose($file);
$strInfo=@unpack('c2chars',$bin);
$typeCode=intval($strInfo['chars1'].$strInfo['chars2']);
$fileType='';
switch($typeCode){
case7790:
$fileType='exe';
break;
case7784:
$fileType='midi';
break;
case8297:
$fileType='rar';
break;
case255216:
$fileType='jpg';
break;
case7173:
$fileType='gif';
break;
case6677:
$fileType='bmp';
break;
case13780:
$fileType='png';
break;
default:
echo'unknown';
break;
}
echo'文件类型:'.$fileType.'文件头信息:'.$typeCode;
希望对你有用!
G. 怎么用php实现文件的上传,要求文件类型为jpg,大小不超过2m,上传的文件存放在u
$_FILES官方文档
你可以看看官方的$_FILES文档,里面有对$_FILES的内容的解释。
想通过PHP来处理文件信息就得通过$_FILES的内容来处理,比如文件类型可以用type来判断,要求文件类型为jpg,那就判断if ($_FILES['file1']['type'] === 'image/jpeg'),这里的file1并不是绝对的,视情况而定。
当然如果你觉得判断类型太麻烦,你也可以直接从name中判断后缀名,自己将文件名分割一下就好了。大小可以用size,默认单位是字节,不超过2M就要除以1024*1024了,可以将字节转换到兆字节。
要将上传的文件放在U目录下,就用move_uploaded_file函数来解决,move_uploaded_file官方文档
H. Think PHP自带的上传文件类,
上传表单
在ThinkPHP中使用上传功能无需进行特别处理。例如,下面是一个带有附件上传的表单提交:
<form action="__URL__/upload" enctype="multipart/form-data" method="post" >
<input type="text" name="name" />
<input type="file" name="photo" />
<input type="submit" value="提交" >
</form>
注意,要使用上传功能 你的表单需要设置 enctype="multipart/form-data"
多文件上传支持
如果需要使用多个文件上传,只需要修改表单,把
<input type='file' name='photo'>
改为
<input type='file' name='photo1'>
<input type='file' name='photo2'>
<input type='file' name='photo3'>
或者
<input type='file' name='photo[]'>
<input type='file' name='photo[]'>
<input type='file' name='photo[]'>
两种方式的多附件上传系统的文件上传类都可以自动识别。
上传操作
ThinkPHP文件上传操作使用Think\Upload类,假设前面的表单提交到当前控制器的upload方法,我们来看下upload方法的实现代码:
public function upload(){
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->rootPath = './Uploads/'; // 设置附件上传根目录
$upload->savePath = ''; // 设置附件上传(子)目录
// 上传文件
$info = $upload->upload();
if(!$info) {// 上传错误提示错误信息
$this->error($upload->getError());
}else{// 上传成功
$this->success('上传成功!');
}
}
上传类对图片文件的上传安全做了支持,如果企图上传非法的图像文件,系统会提示 非法图像文件。 为了更好的使用上传功能,建议你的服务器开启finfo模块支持
上传参数
在上传操作之前,我们可以对上传的属性进行一些设置,Upload类支持的属性设置包括:
属性 描述
maxSize 文件上传的最大文件大小(以字节为单位),0为不限大小
rootPath 文件上传保存的根路径
savePath 文件上传的保存路径(相对于根路径)
saveName 上传文件的保存规则,支持数组和字符串方式定义
saveExt 上传文件的保存后缀,不设置的话使用原文件后缀
replace 存在同名文件是否是覆盖,默认为false
exts 允许上传的文件后缀(留空为不限制),使用数组或者逗号分隔的字符串设置,默认为空
mimes 允许上传的文件类型(留空为不限制),使用数组或者逗号分隔的字符串设置,默认为空
autoSub 自动使用子目录保存上传文件 默认为true
subName 子目录创建方式,采用数组或者字符串方式定义
hash 是否生成文件的hash编码 默认为true
callback 检测文件是否存在回调,如果存在返回文件信息数组
上面的属性可以通过两种方式传入:
实例化传入
我们可以在实例化的时候直接传入参数数组,例如:
$config = array(
'maxSize' => 3145728,
'rootPath' => './Uploads/',
'savePath' => '',
'saveName' => array('uniqid',''),
'exts' => array('jpg', 'gif', 'png', 'jpeg'),
'autoSub' => true,
'subName' => array('date','Ymd'),
);
$upload = new \Think\Upload($config);// 实例化上传类
关于saveName和subName的使用后面我们会有详细的描述。
动态赋值
支持在实例化后动态赋值上传参数,例如:
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728;
$upload->rootPath = './Uploads/';
$upload->savePath = '';
$upload->saveName = array('uniqid','');
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');
$upload->autoSub = true;
$upload->subName = array('date','Ymd');
上面的设置和实例化传入的效果是一致的。
上传文件信息
设置好上传的参数后,就可以调用Think\Upload类的upload方法进行附件上传,如果失败,返回false,并且用getError方法获取错误提示信息;如果上传成功,就返回成功上传的文件信息数组。
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->rootPath = './Uploads/'; // 设置附件上传根目录
$upload->savePath = ''; // 设置附件上传(子)目录
// 上传文件
$info = $upload->upload();
if(!$info) {// 上传错误提示错误信息
$this->error($upload->getError());
}else{// 上传成功 获取上传文件信息
foreach($info as $file){
echo $file['savepath'].$file['savename'];
}
}
每个文件信息又是一个记录了下面信息的数组,包括:
属性 描述
key 附件上传的表单名称
savepath 上传文件的保存路径
name 上传文件的原始名称
savename 上传文件的保存名称
size 上传文件的大小
type 上传文件的MIME类型
ext 上传文件的后缀类型
md5 上传文件的md5哈希验证字符串 仅当hash设置开启后有效
sha1 上传文件的sha1哈希验证字符串 仅当hash设置开启后有效
文件上传成功后,就可以使用这些文件信息来进行其他的数据操作,例如保存到当前数据表或者单独的附件数据表。
例如,下面表示把上传信息保存到数据表的字段:
$model = M('Photo');
// 取得成功上传的文件信息
$info = $upload->upload();
// 保存当前数据对象
$data['photo'] = $info[0]['savename'];
$data['create_time'] = NOW_TIME;
$model->add($data);
单文件上传
upload方法支持多文件上传,有时候,我们只需要上传一个文件,就可以使用Upload类提供的uploadOne方法上传单个文件,例如:
public function upload(){
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->rootPath = './Uploads/'; // 设置附件上传根目录
// 上传单个文件
$info = $upload->uploadOne($_FILES['photo1']);
if(!$info) {// 上传错误提示错误信息
$this->error($upload->getError());
}else{// 上传成功 获取上传文件信息
echo $info['savepath'].$info['savename'];
}
}
uploadOne方法上传成功后返回的文件信息和upload方法的区别是只有单个文件信息的一维数组。
上传文件的命名规则
上传文件的命名规则(saveName)用于确保文件不会产生冲突或者覆盖的情况。命名规则的定义可以根据你的业务逻辑来调整,不是固定的。例如,如果你采用时间戳的方式来定义命名规范,那么在同时上传多个文件的时候可能产生冲突(因为同一秒内可以上传多个文件),因此你需要根据你的业务需求来设置合适的上传命名规则。这里顺便来说下saveName参数的具体用法。
一、采用函数方式
如果传入的字符串是一个函数名,那么表示采用函数动态生成上传文件名(不包括文件后缀),例如:
// 采用时间戳命名
$upload->saveName = 'time';
// 采用GUID序列命名
$upload->saveName = 'com_create_guid';
也可以采用用户自定义函数
// 采用自定义函数命名
$upload->saveName = 'myfun';
默认的命名规则设置是采用uniqid函数生成一个唯一的字符串序列。
saveName的值支持数组和字符串两种方式,如果是只有一个参数或者没有参数的函数,直接使用字符串设置即可,如果需要传入额外的参数,可以使用数组方式,例如:
// 采用date函数生成命名规则 传入Y-m-d参数
$upload->saveName = array('date','Y-m-d');
// 如果有多个参数需要传入的话 可以使用数组
$upload->saveName = array('myFun',array('__FILE__','val1','val2'));
如果需要使用上传的原始文件名,可以采用__FILE__传入,所以上面的定义规则,最终的结果是 myFun('上传文件名','val1','val2')执行的结果。
二、直接设置上传文件名
如果传入的参数不是一个函数名,那么就会直接当做是上传文件名,例如:
$upload->saveName = time().'_'.mt_rand();
表示上传的文件命名采用时间戳加一个随机数的组合字符串方式。
当然,如果觉得有必要,你还可以固定设置一个上传文件的命名规则,用于固定保存某个上传文件。
$upload->saveName = 'ThinkPHP';
三、保持上传文件名不变
如果你想保持上传的文件名不变,那么只需要设置命名规范为空即可,例如:
$upload->saveName = '';
一般来说不建议保持不变,因为会导致相同的文件名上传后被覆盖的情况。
子目录保存
saveName只是用于设置文件的保存规则,不涉及到目录,如果希望对上传的文件分子目录保存,可以设置autoSub和subName参数来完成,例如:
// 开启子目录保存 并以日期(格式为Ymd)为子目录
$upload->autoSub = true;
$upload->subName = array('date','Ymd');
可以使用自定义函数来保存,例如:
// 开启子目录保存 并调用自定义函数get_user_id生成子目录
$upload->autoSub = true;
$upload->subName = 'get_user_id';
和saveName参数一样,subName的定义可以采用数组和字符串的方式。
注意:如果get_user_id函数未定义的话,会直接以get_user_id字符串作为子目录的名称保存。
子目录保存和文件命名规则可以结合使用。
上传驱动
上传类可以支持不同的环境,通过相应的上传驱动来解决,默认情况下使用本地(Local)上传驱动,当然,你还可以设置当前默认的上传驱动类型,例如:
'FILE_UPLOAD_TYPE' => 'ftp',
'UPLOAD_TYPE_CONFIG' => array(
'host' => '192.168.1.200', //服务器
'port' => 21, //端口
'timeout' => 90, //超时时间
'username' => 'ftp_user', //用户名
'password' => 'ftp_pwd', //密码 ),
表示当前使用Ftp作为上传类的驱动,上传的文件会通过FTP传到指定的远程服务器。
也可以在实例化上传类的时候指定,例如:
$config = array(
'maxSize' = 3145728,
'rootPath' = './Uploads/',
'savePath' = '',
'saveName' = array('uniqid',''),
'exts' = array('jpg', 'gif', 'png', 'jpeg'),
'autoSub' = true,
'subName' = array('date','Ymd'),
);
$ftpConfig = array(
'host' => '192.168.1.200', //服务器
'port' => 21, //端口
'timeout' => 90, //超时时间
'username' => 'ftp_user', //用户名
'password' => 'ftp_pwd', //密码 );
$upload = new \Think\Upload($config,'Ftp',$ftpConfig);// 实例化上传类
I. PHP如何上传文件
$f_type=strtolower("swf,rar,jpg,zip,7z,iso,gif,exe,rmvb");//设置可上传的文件类型
if (!is_uploaded_file($file) || ($_FILES['photoupload']['size'] > 20000 * 1024 * 1024) )
{
$error = 'Please upload only files smaller than 2Mb!';
}
$f_name=$_FILES['photoupload']['name'];
$tmp_type=substr(strrchr($f_name,"."),1);//获取文件扩展名
$tmp_type=strtolower($tmp_type);
if(!stristr($f_type,$tmp_type)){
$error="对不起,不能上传格式为:".$tmp_type."的文件:".$f_name;
}
if(move_uploaded_file($_FILES['photoupload']['tmp_name'], $uploadfile)){
$result['result'] = 'success';
$result['size'] =$f_name."文件上传成功";
}
else{
$result['result'] = 'failed';
$result['error'] =$f_name."上传失败";
}