天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

PHP文件上傳實(shí)例詳解!!!

首先來(lái)看下上傳部分的表單代碼:  
復(fù)制代碼 代碼如下:     <form method="post" action="upload.php" enctype="multipart/form-data">  
     <table border=0 cellspacing=0 cellpadding=0 align=center width="100%">  
      <tr>   
        <td width=55 height=20 align="center"><input type="hidden" name="MAX_FILE_SIZE" value="2000000">文件: </TD>  
        <td height="16">   
        <input name="file" type="file"  value="瀏覽" >             
        < input type="submit" value="上傳" name="B1">  
        </td>  
      </tr>  
     </table>  
     </form>  

這里有幾個(gè)要注意的地方,首先看這句<form method="post" action="upload.php" enctype="multipart/form-data">,這里我們采用POST方法,個(gè)別瀏覽器還支持PUT方法,當(dāng)然這需要對(duì)腳本進(jìn)行修改,我并不建議這么做。表單中必須設(shè)置enctype="multipart/form-data,這樣,服務(wù)器就知道上傳文件帶有常規(guī)表單信息,記住,這個(gè)是必須設(shè)置的。此外還需要一個(gè)隱藏域來(lái)限制上傳文件的最大長(zhǎng)度:<input type="hidden" name="MAX_FILE_SIZE" value="2000000">,這里name必須設(shè)置成MAX_FILE_SIZE,其值就是上傳文件的最大長(zhǎng)度,單位是B,這里我限制成2M。再看這句:<input name="file" type="file"  value="瀏覽" >,type="file"說(shuō)明了文件類型,這樣一個(gè)基本的上傳文件接口就完成了,接下來(lái)講講如何用php來(lái)處理上傳的文件,此外你的php.ini中設(shè)置的上傳文件最大長(zhǎng)度可能會(huì)影響到你的實(shí)際上傳,請(qǐng)根據(jù)實(shí)際情況修改,另php的上傳是先傳到臨時(shí)目錄,在移至指定目錄的,了;臨時(shí)目錄的可根據(jù)需要修改,也可使用默認(rèn)值。 
   好的,表單提交upload.php,來(lái)看看這個(gè)頁(yè)面都有什么: 
php代碼如下:  
復(fù)制代碼 代碼如下:<?php  
 /*****************************************  
   Title :文件上傳詳解  
   Author:leehui1983(輝老大)  
   Finish Date  :2006-12-28  
  *****************************************/  
   $uploaddir = "./files/";//設(shè)置文件保存目錄 注意包含/      
   $type=array("jpg","gif","bmp","jpeg","png");//設(shè)置允許上傳文件的類型   
   $patch="http://127.0.0.1/cr_downloadphp/upload/files/";//程序所在路徑  

   //獲取文件后綴名函數(shù)  
      function fileext($filename)  
    {  
        return substr(strrchr($filename, '.'), 1);  
    }  
   //生成隨機(jī)文件名函數(shù)      
    function random($length)  
    {  
        $hash = 'CR-';  
        $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789abcdefghijklmnopqrstuvwxyz';  
        $max = strlen($chars) - 1;  
        mt_srand((double)microtime() * 1000000);  
            for($i = 0; $i < $length; $i++)  
            {  
                $hash .= $chars[mt_rand(0, $max)];  
            }  
        return $hash;  
    }  
   $a=strtolower(fileext($_FILES['file']['name']));  
   //判斷文件類型  
   if(!in_array(strtolower(fileext($_FILES['file']['name'])),$type))  
     {  
        $text=implode(",",$type);  
        echo "您只能上傳以下類型文件: ",$text,"<br>";  
     }  
   //生成目標(biāo)文件的文件名      
   else{  
    $filename=explode(".",$_FILES['file']['name']);  
        do  
        {  
            $filename[0]=random(10); //設(shè)置隨機(jī)數(shù)長(zhǎng)度  
            $name=implode(".",$filename);  
            //$name1=$name.".Mcncc";  
            $uploadfile=$uploaddir.$name;  
        }  
   while(file_exists($uploadfile));  
        if (move_uploaded_file($_FILES['file']['tmp_name'],$uploadfile)){  

            if(is_uploaded_file($_FILES['file']['tmp_name'])){  
                //輸出圖片預(yù)覽  
                echo "<center>您的文件已經(jīng)上傳完畢 上傳圖片預(yù)覽: </center><br><center><img src='$uploadfile'></center>";  
                echo"<br><center><a href='Javascript:history.go(-1)'>繼續(xù)上傳</a></center>";  
              }  
              else{  
                echo "上傳失敗!";  
              }  
        }  
   }   
?>  
剛看這些你可能有點(diǎn)暈~~,不過(guò)不要緊,聽我講完,你就會(huì)發(fā)現(xiàn)其實(shí)這玩意SO EASY!!首先我講下原理,該程序以上傳圖片為例,先判斷文件類型是否為圖片格式,若是則上傳文件,以隨機(jī)數(shù)和時(shí)間的組合重新命名文件(避免上傳文件重名,這樣做很有必要!),接著上傳文件到指定目錄,成功上傳則輸出上傳的圖片預(yù)覽。這里要對(duì)程序中一些函數(shù)作些解釋。先看return substr(strrchr($filename, '.'), 1), strrchar()函數(shù)有什么作用呢,我舉個(gè)例子大家就知道,比如一個(gè)圖片文件 pic.jpg,我們用 strrchr處理,strrchr(pic.jpg,'.'),它將返回.jpg,明白了嗎?該函數(shù)返回指定字符在該字符串最后出現(xiàn)的位置后的字符。配合 substr() 我們就可以取到j(luò)pg,這樣我們就得到了文件的后綴名,來(lái)判斷上傳文件是否符合指定格式。本程序把指定的格式放在一個(gè)數(shù)組中,實(shí)際使用時(shí)可根據(jù)需要添加。 
    接下來(lái)看產(chǎn)生隨機(jī)數(shù)文件名部分, 我們看到mt_srand()這個(gè)函數(shù),手冊(cè)上叫他“播下一個(gè)更好的隨機(jī)數(shù)發(fā)生器種子”,其實(shí)就是初始化一個(gè)隨機(jī)數(shù)的函數(shù),參數(shù)是(double)microtime() * 1000000,這里如果不這是參數(shù)就會(huì)自動(dòng)設(shè)置個(gè)隨機(jī)數(shù),當(dāng)然這不符合我們的需要,如此一來(lái),隨機(jī)數(shù)就具備一定的長(zhǎng)度,保證了上傳文件不重名。接著,我們調(diào)用判斷文件類型的函數(shù),并將其轉(zhuǎn)化為小寫strtolower(fileext($_FILES['file']['name'])),這里有個(gè)很關(guān)鍵的東東$_FILES ,這是個(gè)超級(jí)全局?jǐn)?shù)組,保存了需要處理的表單數(shù)據(jù),如果開啟了register_globals,也可以直接訪問(wèn),但這是不安全的。看剛才那個(gè)上傳接口<input name="file" type="file"  value="瀏覽" >,根據(jù)這個(gè)表單名稱,我們可以得到很多信息: 
    $_FILES['file']['name']--  得到文件名稱 
    $_FILES['file']['tmp_name']--得到臨時(shí)存儲(chǔ)位置 
    $_FILES['file']['size']--得到文件大小 
    $_FILES['file']['type']--得到文件MIME類型 
得到這些信息,我們就可以輕松判斷文件的信息了,是不是很方便?^_^,接下來(lái)還有一些函數(shù)需要了解,file_exists()--判斷指定目錄是否存在,不存在我們當(dāng)然不能上傳(好像是廢話!),move_uploaded_file--將上傳文件移至指定目錄,is_uploaded_file--判斷文件是否已經(jīng)通過(guò)HTTP POST上傳。成功上傳,我們就輸出預(yù)覽,否則輸出上傳失敗!大功告成 
   大家可根據(jù)這個(gè)進(jìn)行擴(kuò)展,比如配合JS實(shí)現(xiàn)多文件上傳,如DZ的上傳效果,再深一點(diǎn)結(jié)合AJAX實(shí)現(xiàn)無(wú)刷新上傳,很多博客都有采用,最后播放下下兩篇原創(chuàng)文章的預(yù)告 
1  我將把這個(gè)例子擴(kuò)展,增加后臺(tái)和數(shù)據(jù)庫(kù)部分,實(shí)現(xiàn)上傳文件管理,審核,將發(fā)布在原創(chuàng)區(qū)。 
2  利用目錄函數(shù)實(shí)現(xiàn)文件管理,將發(fā)布在新手區(qū) 
希望感興趣的朋友屆時(shí)觀看~~~,謝謝!!!!!!

php技術(shù)PHP文件上傳實(shí)例詳解!!!,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 激情男女高潮射精AV免费 | 亚洲精品久久久992KVTV | 国产精品99久久久精品无码 | 亚洲日韩国产成网站在线 | 富婆大保健嗷嗷叫普通话对白 | 97在线观看成人免费视频 | 在线一本码道高清 | 东京热 百度影音 | 国产 浪潮AV性色四虎 | 巨胸美乳中文在线观看 | 夫外出被公侵犯日本电影 | 天天躁日日躁狠狠躁午夜剧场 | 噼里啪啦免费观看视频大全 | 日韩精品久久久久久久电影 | 无码AV精品一区二区三区 | 久久久久久人精品免费费看 | 成人午夜精品久久久久久久秋霞 | 国产亚洲精品久久久999密臂 | 最近免费中文字幕MV免费高清 | 幸福草电视剧演员表介绍 | 国产精品999 | 成人毛片免费播放 | 国产午夜精品自在自线之la | 亚洲地址一地址二地址三 | 精品国产自在自线官方 | 成年黄网站免费大全毛片 | 一二三四在线观看高清电视剧 | 日本特黄的免费大片视频 | 国产97精品久久久天天A片 | 亚洲国产cao | 国产精品免费观看视频播放 | 99久久国产综合精品 | 国产精品女主播主要上线 | 污到湿的爽文免费阅读 | 人妻体内射精一区二区 | 国产综合91 | 青草久久久 | 97影院午夜午夜伦不卡 | 一二三四韩国免费观看 | 手机看片国产免费久久网 | 公粗挺进了我的密道在线播放贝壳 |