亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

PHP實(shí)現(xiàn)文件上傳下載之封裝上傳函數(shù)

封裝上傳函數(shù)

我們將上面上傳功能封裝成函數(shù),代碼如下:

fun_upload.php

<?php
//定義一個(gè)uploadFile函數(shù)
function uploadFile($fileInfo,$path,$allowExt,$maxSize){
//取出$_FILES中的數(shù)據(jù)
$filename=$fileInfo["name"];
$tmp_name=$fileInfo["tmp_name"];
$size=$fileInfo["size"];
$error=$fileInfo["error"];
$type=$fileInfo["type"];
//取出文件路徑中文件的類型的部分
$ext=pathinfo($filename,PATHINFO_EXTENSION);
//確定是否存在存放圖片的文件夾,沒(méi)有則新建一個(gè)
if (!file_exists($path)) {  //當(dāng)目錄不存在,就創(chuàng)建目錄
  mkdir($path,0777,true);//創(chuàng)建目錄
  chmod($path, 0777);//改變文件模式,所有人都有執(zhí)行權(quán)限、寫(xiě)權(quán)限、度權(quán)限
}
//得到唯一的文件名!防止因?yàn)槲募嗤a(chǎn)生覆蓋
$uniName=md5(uniqid(microtime(true),true)).'.'.$ext;
//目標(biāo)存放文件地址
$destination=$path."/".$uniName;
//當(dāng)文件上傳成功,存入臨時(shí)文件夾,服務(wù)器端開(kāi)始判斷
if ($error==0) {
  if ($size>$maxSize) {
    exit("上傳文件過(guò)大!");
  }
  if (!in_array($ext, $allowExt)) {
    exit("非法文件類型");
  }
  if (!is_uploaded_file($tmp_name)) {
    exit("上傳方式有誤,請(qǐng)使用post方式");
  }
  //判斷是否為真實(shí)圖片(防止偽裝成圖片的病毒一類的
  if (!getimagesize($tmp_name)) {//getimagesize真實(shí)返回?cái)?shù)組,否則返回false
    exit("不是真正的圖片類型");
  }
  if (@move_uploaded_file($tmp_name, $destination)) {//@錯(cuò)誤抑制符,不讓用戶看到警告
    echo "文件".$filename."上傳成功!";
  }else{
    echo "文件".$filename."上傳失敗!";
  }
}else{
  switch ($error){
    case 1:
      echo "超過(guò)了上傳文件的最大值,請(qǐng)上傳2M以下文件";
      break;
    case 2:
      echo "上傳文件過(guò)多,請(qǐng)一次上傳20個(gè)及以下文件!";
      break;
    case 3:
      echo "文件并未完全上傳,請(qǐng)?jiān)俅螄L試!";
      break;
    case 4:
      echo "未選擇上傳文件!";
      break;
    case 7:
      echo "沒(méi)有臨時(shí)文件夾";
      break;
  }
}
return $destination;
}

表單頁(yè)面采用之前的:

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"> 
 <meta name="format-detection" content="telephone=no" /> 
<title>文件上傳(客戶端限制)</title>
<meta charset="utf-8" />
</head>
<body>
<form action="upload3.php" method="post" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="101321" />
請(qǐng)選擇您要上傳的文件:
<input type="file" name="myFile" accept="image/jpeg,image/gif,text/html"/><br/>
<input type="submit" value="上傳"/>
</form>
</body>
</html>

提交處理頁(yè)面

upload3.php

<?php
header('content-type:text/html;charset=utf-8');
//初始化相關(guān)變量
$fileInfo=$_FILES["myFile"];
$maxSize=10485760;//10M,10*1024*1024
$allowExt=array('jpeg','jpg','png','tif');
$path="uploads";
//引入前面封裝了的上傳函數(shù)fun_upload.php
include_once 'fun_upload.php';
uploadFile($fileInfo, $path, $allowExt, $maxSize);

注釋很詳細(xì),大家可以復(fù)制到本地邊測(cè)試邊學(xué)習(xí)

封裝了,我們以后使用就可以直接調(diào)用了,是不是很方便,下一節(jié)的多文件上傳就將用到我們封裝好的這個(gè)函數(shù)

繼續(xù)學(xué)習(xí)
||
<!DOCTYPE html> <html> <head> <meta name="viewport" content="width=device-width, initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"> <meta name="format-detection" content="telephone=no" /> <title>文件上傳(客戶端限制)</title> <meta charset="utf-8" /> </head> <body> <form action="upload3.php" method="post" enctype="multipart/form-data"> <input type="hidden" name="MAX_FILE_SIZE" value="101321" /> 請(qǐng)選擇您要上傳的文件: <input type="file" name="myFile" accept="image/jpeg,image/gif,text/html"/><br/> <input type="submit" value="上傳"/> </form> </body> </html>
提交重置代碼