一個簡單的php文件上傳的類,在整理 php 類時發現的一個圖片處理類,PHP 處理圖片的類已經很多了,有單獨處理圖片的,也有加水印的,也有生成圖片的,總之,在 PHP 當中,處理圖片已經很簡單了,甚至在一些小型的應用中,直接應用 PHP 的面向過程就可以實現圖片的上傳過程,當然,為了程序的規范,我們還是有必要使用PHP的面向對象的
下面的這個PHP文件的上傳類主要是用來上傳文件的,包括圖片,視頻,word文檔的,其實這裡建議用來處理圖片,推薦的主要原因是這個類很規范,基本上所有的上傳參數都可以在類裡面進行定義,而不需要在 php.ini 裡面進行修改
代碼如下 復制代碼<?php
class files{
/**
* upload
*
* 文件上傳
*
* @param String $path e.g. Zend_Registry::get('upload')
* @param Array $files e.g. $_FILES['Filedata']
* @param String $dir e.g. $_POST['dir']
*
* return Array $msg e.g. if($msg['error'])
*/
static function upload($path,$files,$dir)
{
$msg=array();
//文件保存目錄路徑
$save_path = $path;
//文件保存目錄URL
$save_url = $path;
//定義允許上傳的文件擴展名
$ext_arr = array(
'image' => array('gif', 'jpg', 'jpeg', 'png', 'bmp'),
'flash' => array('swf', 'flv'),
'media' => array('swf', 'flv', 'mp3', 'wav', 'wm
a', 'wmv', 'mid', 'avi', 'mpg', 'asf', 'rm', 'rmvb'),
'file' => array('doc', 'docx', 'xls', 'xlsx', 'pp
t', 'htm', 'html', 'txt', 'zip', 'rar', 'gz', 'bz2'),
);
//最大文件大小
$max_size = 1000000;
$save_path = realpath($save_path) . '/';
//有上傳文件時
if (empty($_FILES) === false) {
//原文件名
$file_name = $files['name'];
//服務器上臨時文件名
$tmp_name = $files['tmp_name'];
//文件大小
$file_size = $files['size'];
//目錄名
$dir_name = empty($dir) ? 'image' : trim($dir);
//檢查文件名
if (!$file_name) {
$msg['error'] = "請選擇文件。";
}
//檢查目錄
else if (@is_dir($save_path) === false) {
$msg['error'] = "上傳目錄不存在。請聯系管理員";
}
//檢查目錄寫權限
else if (@is_writable($save_path) === false) {
$msg['error'] = "上傳目錄沒有寫權限。請聯系管理員";
}
//檢查是否已上傳
else if (@is_uploaded_file($tmp_name) === false) {
$msg['error'] = "臨時文件可能不是上傳文件。請重新上傳";
}
//檢查文件大小
else if ($file_size > $max_size) {
$msg['error'] = "上傳文件大小超過限制。";
}
//檢查目錄名
else if (empty($ext_arr[$dir_name])) {
$msg['error'] = "目錄名不正確。";
}
else
{
//獲得文件擴展名
$temp_arr = explode(".", $file_name);
$file_ext = array_pop($temp_arr);
$file_ext = trim($file_ext);
$file_ext = strtolower($file_ext);
//檢查擴展名
if (in_array($file_ext, $ext_arr[$dir_name]) === false) {
$msg['error'] = "上傳文件擴展名是不允許的擴展名。
n只允許" . implode(",", $ext_arr[$dir_name]) . "格式。";
}
else
{
//創建文件夾
$dbsave = ""; //數據庫中存放的路徑
if ($dir_name !== '') {
$save_path .= $dir_name . "/";
$save_url .= $dir_name . "/";
$dbsave = $dir_name.'/';
if (!file_exists($save_path)) {
mkdir($save_path);
}
}
$y = date("Y");
$m = date("m");
$d = date("d");
$save_path .= $y . "/";
$save_url .= $y . "/";
$dbsave .= $y.'/';
if (!file_exists($save_path)) {
mkdir($save_path);
}
$save_path .= $m . "/";
$save_url .= $m . "/";
$dbsave .= $m.'/';
if (!file_exists($save_path)) {
mkdir($save_path);
}
$save_path .= $d . "/";
$save_url .= $d . "/";
$dbsave .= $d.'/';
if (!file_exists($save_path)) {
mkdir($save_path);
}
//新文件名
$new_file_name = date("YmdHis") . '_' . rand(1000
0, 99999) . '.' . $file_ext;
//移動文件
$file_path = $save_path . $new_file_name;
if (move_uploaded_file($tmp_name, $file_path) === false) {
$msg['error'] = "上傳文件失敗。";
}
//數據庫最終存儲的文件
$dbsave .= $new_file_name;
@chmod($file_path, 0644);
$file_url = $save_url . $new_file_name;
$msg['file_url'] = $file_url;
$msg['file_size'] = $file_size;
$msg['db_path'] = $dbsave;
}//檢查擴展名
}//目錄正確性
return $msg;
}
}
//文件上傳
}
?>
通過使用 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"] - 由文件上傳導致的錯誤代碼
這是一種非常簡單文件上傳方式。基於安全方面的考慮,您應當增加有關什麼用戶有權上傳文件的限制。