一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

PHP5+UTF8多文件上傳類

還有些功能沒有加上去,如自動更名,圖片處理等.可根據需要自己添加.
USE:
$up = new upfile(ROOT_PATH.'data/'.date("Ym",time()),array('gif','jpg','jpeg'),true);
$fileimg = $up->upload($_FILES['img']);//返回上傳后文件名數組,$_FILES['img']為上傳的文件
可使用$up->log查看上傳時信息.
<?php
//====================================================
// FileName: upfile.class.php
// Summary: 文件上傳類
// Author: millken(迷路林肯)
// LastModifed: 2008-6-4
// copyright (c)2008 millken@gmail.com
//====================================================
if(!defined('OK'))exit(__FILE__.'Access Denied');
class upfile {
public $ExtensionFileFormat = array();
public $returninfo = array();
private $ImageFileFormat = array('gif','bmp','jpg','jpe','jpeg','png');
private $OtherFileFormat = array('zip','pdf','rar','xls','doc','ppt','csv');
private $savePath;
private $attachment_path = './upfiles/';
private $overwrite = false; # 同名時是否覆蓋
private $maxSize = 0; # 文件最大字節,為0時不限制大小
private $ext;
private $errno = 0;
/* 構造函數
* (string)$savePath 文件保存路徑,默認為$attachment_path
* (array)$extensionFileFormat 自定義上傳文件的擴展名,未設置時為$ImageFileFormat || $OtherFileFormat
* (bool)$overwrite 是否覆蓋同名文件
*/
public function __construct($savePath='',$extensionFileFormat = array(),$overwrite = false) {
$this->savePath = empty($savePath)?$this->attachment_pathsavePath.'/';
$this->extensionFileFormat = is_array($extensionFileFormat)?$extensionFileFormat:array();
$this->overwrite = is_bool($overwrite)?$overwrite:false;
}
/*上傳函數
* (array)$files 待上傳的文件數組$_FILES['attach']
* (number)$maxSize 文件的最大字節數,默認為0不限制上傳大小
*/
public function upload($files,$maxSize=0) {
$this->maxSize = is_numeric($maxSize)?$maxSize:0;
if(isset($files) && is_array($files)) {
if(is_array($files['name'])) {
foreach($files as $key => $var) {
foreach($var as $id => $val) {
$attachments[$id][$key] = $val;
}
}
} else {
$attachments[] = $files;
}
}
self::check_file_type($attachments);
if(empty($this->filelist)) {
$this->log .= "待上傳的文件列表為空。/n";
return array();
}
if(!self::makeDirectory() || !@is_writable($this->savePath)) {
$this->log .= $this->savePath . "不能創建或其權限為不可寫。/n";
return array();
}
$filearray = array();
foreach($this->filelist as $k=>$f) {
if($this->maxSize && $f['size']>$this->maxSize) {
$this->log .= $f['name'] . "其大小超過了設定的值:" . $this->maxSize ."/n";
}elseif($this->overwrite == false && file_exists($this->savePath . $f['name'])) {
$this->log .= $f['name'] . "已經存在于目錄:" . $this->savePath . "/n";
}else{
@unlink($this->savePath . $f['name']);
if(@move_uploaded_file($f['tmp_name'],$this->savePath . mb_convert_encoding($f['name'],'gbk','utf-8'))) {//如果不進行編碼轉換,中文將無法支持
$this->log .= $f['name'] . "成功上傳到目錄:". $this->savePath ."/n";
$filearray[$k] = $this->savePath . $f['name'];
}else{
$this->log .= $f['name'] . "上傳失敗。/n";
}
}
}
return $filearray;
}
/*檢測文件的類型
*(array)$files 文件數組
*/
private function check_file_type($files) {
$this->filelist = array();
foreach($files as $key=>$file) {
if($file['error'] == 0) {
$ext = strtolower(substr($file['name'], strrpos($file['name'], '.') + 1));
$str = @file_get_contents($file['tmp_name'],FALSE,NULL,0,20);
if((in_array($ext,array('jpg','jpeg')) && substr($str ,0, 3) !== "/xFF/xD8/xFF") || ($ext == 'gif' && substr($str ,0, 4) !== 'GIF8') || ($ext == 'png' && substr($str ,0, 8) !== "/x89/x50/x4E/x47/x0D/x0A/x1A/x0A") || ($ext == 'bmp' && substr($str ,0, 2) !== 'BM') || ($ext == 'swf' && (substr($str ,0, 3) !== 'CWS' || substr($str ,0, 3) !== 'FWS')) || ($ext == 'zip' && substr($str ,0, 4) !== "PK/x03/x04") || ($ext == 'rar' && substr($str ,0, 4) !== 'Rar!') || ($ext == 'pdf' && substr($str ,0, 4) !== "/x25PDF") || ($ext == 'chm' && substr($str ,0, 4) !== 'ITSF') || ($ext == 'rm' && substr($str ,0, 4) !== "/x2ERMF") || ($ext == 'exe' && substr($str ,0, 2) !== "MZ") || (in_array($ext,array('doc','xls','ppt')) && substr($str ,0, 4) !== "/xD0/xCF/x11/xE0")) {
$this->log .= $file['name'] . "文件類型與文件內容不符合。/n";
}elseif((!empty($this->extensionFileFormat) && in_array($ext,$this->extensionFileFormat)) || (empty($this->extensionFileFormat) && (in_array($ext,$this->ImageFileFormat) || in_array($ext,$this->OtherFileFormat)))) {
$this->filelist[$key] = $file;
}else{
$this->log .= $file['name'] . "不符合上傳文件的類型。/n";
@unlink($file['tmp_name']);
}
}
}
}
/*生成上傳目錄
*
*/
private function makeDirectory() {
$directoryName = str_replace("http://","/", $this->savePath);
$dirNames = explode('/', $directoryName);
$total = count($dirNames);
$temp = '';
for($i=0; $i<$total; $i++)
{
$temp .= $dirNames[$i].'/';
if (!is_dir($temp))
{
$oldmask = @umask(0);
if (!@mkdir($temp, 0777)) return false;
@umask($oldmask);
}
};
if(is_dir($this->savePath)) {
return true;
} else {
return false;
};
}
}
?>

php技術PHP5+UTF8多文件上傳類,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久国内精品自在自线观看 | 色网站在线 | 久久精品国产999久久久 | 最新国产视频 | www视频免费| 亚洲美女人黄网成人女 | 激情五月宗合网 | 欧洲精品在线视频 | 日本一区二区三区四区视频 | 日韩午夜视频在线观看 | 国产爆操| 亚洲乱码一二三四区国产 | 91香蕉福利一区二区三区 | 精品久久久久久久久久久久久久久 | 亚洲精品tv久久久久久久久 | 国产99r视频精品免费观看 | 亚洲天堂中文网 | 亚洲欧美日韩视频一区 | 美女扒开屁股让男人桶视频网站 | 国产亚洲玖玖玖在线观看 | 97色婷婷成人综合在线观看 | 亚洲成人伊人网 | 日韩在线一区二区三区免费视频 | 婷婷色在线观看 | 在线观看日本亚洲一区 | 韩国福利影视一区二区三区 | 黄色网址中文字幕 | 精品无人区一区二区三区 | 38pao强力打造永久免费高清视频 | 真实国产乱弄免费视频 | 欧美成人免费全部观看天天性色 | 国产在线精品一区二区三区不卡 | 国产真实乱在线更新 | 日韩中文字幕免费在线观看 | 亚洲第一se情网站 | 欧美日韩免费大片 | 国产专区自拍 | 中文字幕激情 | 亚洲五月婷 | 在线一区观看 | 久久久噜噜噜久久久午夜 |