欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

PHP如何實(shí)現(xiàn)單文件、多個(gè)單文件、多文件上傳函數(shù)的封裝-創(chuàng)新互聯(lián)

創(chuàng)新互聯(lián)www.cdcxhl.cn八線動(dòng)態(tài)BGP香港云服務(wù)器提供商,新人活動(dòng)買多久送多久,劃算不套路!

阜陽(yáng)ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!

本篇文章給大家分享的是有關(guān)PHP如何實(shí)現(xiàn)單文件、多個(gè)單文件、多文件上傳函數(shù)的封裝,小編覺(jué)得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。

表單:

s.php

要在選擇上傳文件時(shí)能一次選擇多個(gè)文件,那么就加multiple="multiple" ,還有注意下name="myFile1"name="myFile[]"的區(qū)別,單文件、多文件上傳.

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>無(wú)標(biāo)題文檔</title>
</head>
<body>
<form action="sss.php" method="post" enctype="multipart/form-data">
  <input type="file" name="myFile1" /><br/>
  <input type="file" name="myFile2" /><br/>
  <input type="file" name="myFile[]" /><br/>
  <input type="file" name="myFile[]" /><br/>
  <input type="file" name="myFile[]" multiple="multiple"/><br/>
  <input type="submit" value="上傳文件"/>
</form>
</body>
</html>

上傳函數(shù)的封裝:

ss.php

<?php
header('Content-Type:text/html;charset=utf-8');
//構(gòu)建上傳文件信息
function getFiles(){
    $i=0;
    foreach($_FILES as $file){
        //因?yàn)檫@時(shí)$_FILES是個(gè)三維數(shù)組,并且上傳單文件或多文件時(shí),數(shù)組的第一維的類型不同,這樣就可以拿來(lái)判斷上傳的是單文件還是多文件
        if(is_string($file['name'])){
        //如果是單文件
            $files[$i]=$file;
            $i++;
        }elseif(is_array($file['name'])){
        //如果是多文件
            foreach($file['name'] as $key=>$val){
                $files[$i]['name']=$file['name'][$key];
                $files[$i]['type']=$file['type'][$key];
                $files[$i]['tmp_name']=$file['tmp_name'][$key];
                $files[$i]['error']=$file['error'][$key];
                $files[$i]['size']=$file['size'][$key];
                $i++;
            }
        }
    }
    return $files;
}
//針對(duì)于單文件、多個(gè)單文件、多文件的上傳
//默認(rèn)允許上傳的文件只為圖片類型,并且只有這些圖片類型:$allowExt=array('jpeg','jpg','png','gif');并且檢查上傳的文件是否為真實(shí)的圖片$flag=true
//默認(rèn)上傳保存的文件夾為本地的'uploads'文件夾,允許上傳文件的大小大為2M
function uploadFile($fileInfo,$path='./uploads',$flag=true,$allowExt=array('jpeg','jpg','png','gif'),$maxSize=2097152){
    //判斷錯(cuò)誤號(hào)
    if($fileInfo['error']===UPLOAD_ERR_OK){
        //檢測(cè)上傳文件的大小
        if($fileInfo['size']>$maxSize){
            $res['mes']=$fileInfo['name'].'上傳文件過(guò)大';
        }
        $ext=getExt($fileInfo['name']);
        //檢測(cè)上傳文件的文件類型
        if(!in_array($ext,$allowExt)){
            $res['mes']=$fileInfo['name'].'非法文件類型';
        }
        //檢測(cè)是否是真實(shí)的圖片類型
        if($flag){
            if(!getimagesize($fileInfo['tmp_name'])){
                $res['mes']=$fileInfo['name'].'不是真實(shí)圖片類型';
            }
        }
        //檢測(cè)文件是否是通過(guò)HTTP POST上傳上來(lái)的
        if(!is_uploaded_file($fileInfo['tmp_name'])){
            $res['mes']=$fileInfo['name'].'文件不是通過(guò)HTTP POST方式上傳上來(lái)的';
        }
        if( $res ) return $res; //如果要不顯示錯(cuò)誤信息的話,用if( @$res ) return $res;
        //$path='./uploads';
        //如果沒(méi)有這個(gè)文件夾,那么就創(chuàng)建一
        if(!file_exists($path)){
            mkdir($path,0777,true);
            chmod($path,0777);
        }
        //新文件名唯一
        $uniName=getUniName();
        $destination=$path.'/'.$uniName.'.'.$ext;
        //@符號(hào)是為了不讓客戶看到錯(cuò)誤信,也可以刪除
        if(!@move_uploaded_file($fileInfo['tmp_name'],$destination)){
            $res['mes']=$fileInfo['name'].'文件移動(dòng)失敗';
        }
        $res['mes']=$fileInfo['name'].'上傳成功';
        $res['dest']=$destination;
        return $res;
    }else{
        //匹配錯(cuò)誤信息
        //注意!錯(cuò)誤信息沒(méi)有5
        switch($fileInfo['error']){
            case 1:
                $res['mes'] = '上傳文件超過(guò)了PHP配置文件中upload_max_filesize選項(xiàng)的值';
                break;
            case 2:
                $res['mes'] = '超過(guò)了HTML表單MAX_FILE_SIZE限制的大小';
                break;
            case 3:
                $res['mes'] = '文件部分被上傳';
                break;
            case 4:
                $res['mes'] = '沒(méi)有選擇上傳文件';
                break;
            case 6:
                $res['mes'] = '沒(méi)有找到臨時(shí)目錄';
                break;
            case 7:
                $res['mes'] = '文件寫入失敗';
                break;
            case 8:
                $res['mes'] = '上傳的文件被PHP擴(kuò)展程序中斷';
                break;
        }
        return $res;
    }
}
?>

common.ss.php

<?php
//這兩函數(shù)也可以一起放到ss.php里面去
//得到文件擴(kuò)展名
function getExt($filename){
    return strtolower(pathinfo($filename,PATHINFO_EXTENSION));
}
//產(chǎn)生唯一字符串
function getUniName(){
    return md5(uniqid(microtime(true),true));
}
?>

上傳后文件的操作:

<?php
header("content-type:text/html;charset=utf-8");
require_once 'ss.php';
require_once 'common.ss.php';
$files=getFiles();
//修改允許上傳文件的類型,為('jpeg','jpg','png','gif','html','txt'),也可以增加新的,如pdf,pptx等等
$allowExt=array('jpeg','jpg','png','gif','html','txt');
foreach($files as $fileInfo){
    //修改上傳保存的文件夾為本地的'imooc',如果沒(méi)有這個(gè)文件夾,那么就創(chuàng)建一個(gè)
    //'false'參數(shù):不要檢查上傳的文件是否為真實(shí)的圖片,因?yàn)橐试S上傳除開圖片類型外的其他類型文件,如html、txt
    $res=uploadFile($fileInfo,'imooc',false,$allowExt);
    echo $res['mes'],'<br/>';
    $uploadFiles[]=$res['dest'];//如果要不顯示錯(cuò)誤信息的話,用@$uploadFiles[]=$res['dest'];
}
$uploadFiles=array_values(array_filter($uploadFiles));//這樣便于保存到數(shù)據(jù)庫(kù)
print_r($uploadFiles);//打印查看上傳保存的結(jié)果
?>

以上就是PHP如何實(shí)現(xiàn)單文件、多個(gè)單文件、多文件上傳函數(shù)的封裝,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過(guò)這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

網(wǎng)站欄目:PHP如何實(shí)現(xiàn)單文件、多個(gè)單文件、多文件上傳函數(shù)的封裝-創(chuàng)新互聯(lián)
分享路徑:http://aaarwkj.com/article8/csosop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)、網(wǎng)站改版、Google、ChatGPT、網(wǎng)站排名服務(wù)器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
高清免费在线自偷自拍| 日韩免费色视频一区| 亚洲国内一区二区三区| 色哟哟网站一区二区精品久久| 成人性生交免大片免费| 久久精品免费激情视频| 成人黄色免费在线网站| 久热在线这里只有精品| 丁香六月色婷婷亚洲激情| 国产国语久久91老女人| 日本一欧美一欧美一亚洲| 精品人妻少妇一区二区三| 国产一区二区黄色网页| 欧美日韩国产另类在线视频| 一本色桃子精品久久中文字幕| 丰满人妻被黑人猛烈进入| 亚洲国产精品午夜福利在线播放| 在线免费观看午夜视频| 国产精品播放一区二区三区| 国产成人综合久久二区| 亚洲永久免费精品一区二区三区| 日韩精品成人亚洲天堂| 亚洲熟妇精品一区二区| 欧美性做爰片免费视频网| 2021亚洲精品午夜精品国产| 久久精品国产一区二区三| 91九色国产在线播放| 亚洲国产视频中文字幕| 亚洲高清中文字幕专区| 欧美精品福利一区二区三区| 日韩欧美另类精品在线| 国产精品自拍av一区二区| 高颜值美女后入内射视频| 国产精品水嫩水嫩粉嫩| 国产亚洲一区二区三区午夜| 欧美日韩亚洲国产一区| 亚洲特级黄色做啪啪啪| 蜜桃少妇人妻一区二区视频| 欧美日韩美足一区二区| 香蕉久草官网视频观看| 久久婷婷国产综合精品青草|