[js一點也不難]js+php如何實現(xiàn)上傳圖片

近期有一些朋友,在做上傳圖片這一塊的時候進度卡住了雇庙。有個朋友說,我已經(jīng)在這個問題上浪費了一天了悍赢。
確實援制,對于新手而言戏挡,上傳圖片成了比較復(fù)雜的的一個事,今天整理了一下常用的兩種方式晨仑,讓新手輕松掌握上傳圖片的小難題褐墅。

(一)form表單上傳

這種方式簡單暴力,如果沒有特殊需求洪己,數(shù)據(jù)和圖片一次性處理的時候妥凳,這種方式,最合適不過答捕。

<b>前端的代碼:</b>

<form action="upload" method="post" enctype="multipart/form-data">
  <input type="file" name="pic" />
  <input type="submit" value="上傳" />
</form>
  • action 請求的后端方法
  • enctype="multipart/form-data" 在使用包含文件上傳控件的表單時逝钥,必須使用該值。

<b>后端的代碼:</b>

public function upload(){
    // 獲取上傳的圖片
    $pic = $_FILES['pic']['tmp_name'];
    $upload_ret = false;

    if($pic){
        // 上傳的路徑拱镐,建議寫物理路徑
        $uploadDir = 'static/upload'; 
        // 創(chuàng)建文件夾  
        if(!file_exists($uploadDir)){        
            mkdir($uploadDir, 0777);    
        }    
        // 用時間戳來保存圖片艘款,防止重復(fù)
        $targetFile = $uploadDir . '/' . time() . $_FILES['pic']['name'];    
        // 將臨時文件 移動到我們指定的路徑,返回上傳結(jié)果
        $upload_ret = move_uploaded_file($pic, $targetFile) ? true : false;
    }

    return $upload_ret;
}

簡單的一個form表單上傳文件就搞定了痢站!

(二)ajax 無刷新上傳圖片

傳統(tǒng)的form表單提交會導(dǎo)致頁面刷新磷箕,但是在有些情況下,我們不希望頁面被刷新阵难,這種時候我們都是使用ajax的方式進行請求的岳枷。

很多人肯定會想到JQuery的ajax操作,但是這樣的做法是沒用的,因為只能傳遞一般的參數(shù)空繁,文件是無法上傳的殿衰。
這個時候 有一個叫做FormData的東西的出現(xiàn)拯救了我們

關(guān)于FormData

XMLHttpRequest Level 2添加了一個新的接口FormData,利用FormData對象盛泡,我們可以通過JavaScript用一些鍵值對來模擬一系列表單控件闷祥,我們還可以使用XMLHttpRequest的send()方法來異步的提交這個"表單"。比起普通的ajax傲诵,使用FormData的最大優(yōu)點就是我們可以異步上傳一個二進制文件凯砍。
所有主流瀏覽器的較新版本都已經(jīng)支持這個對象了,比如Chrome 7+拴竹、Firefox 4+悟衩、IE 10+、Opera 12+栓拜、Safari 5+座泳。

參見:https://developer.mozilla.org/zh-CN/docs/Web/API/FormData

  • 原生的XMLHttpRequest 實現(xiàn)

前端的代碼:

<form>
  <input type="file" name="pic" id="pic"/>
  <input type="button" onClick="upload()" value="上傳" />
</form>    

js的代碼:

function upload(){
    // 請求的后端方法
    var url="upload";
    // 獲取文件
    var pic = document.getElementById('pic').files[0];

    // 初始化一個 XMLHttpRequest 對象
    var xhr = new XMLHttpRequest();
    // 初始化一個 FormData 對象
    var form = new FormData();

    // 攜帶文件
    form.append("pic", pic);
    //開始上傳
    xhr.open("POST", url, true);
    //在readystatechange事件上綁定一個事件處理函數(shù)
    xhr.onreadystatechange=callback;
    xhr.send(form);

    function callback() {
        if(xhr.readyState == 4){
            if(xhr.status == 200){
                if(xhr.responseText == 1){
                    alert('添加成功');
                    window.location.reload();
                }else{
                   alert("添加失敗");
               }
            }
        }
   }
}

參見:https://developer.mozilla.org/zh-CN/docs/Web/Guide/Using_FormData_Objects

后端代碼:
如方法一,不變幕与。

  • JQuery + FormData 實現(xiàn)

其實JQuery也是可以操作的挑势,不過老版本不支持,所以建議使用2.0及更新版本啦鸣。

前端代碼:

<form id= "upload_form">  
  指定文件名:<input type="text" name="filename" />
  上傳文件:<input type="file" name="file"/>
  <input type="button" value="上傳" onclick="upload()" />  
</form>  

js代碼:

function upload(){  
    var form = new FormData($("#upload_form")[0]);  
    $.ajax({  
      url:'upload',  
      type:'POST',  
      data:form,  
      success:function (result){  
        alert(result);  
      },  
      error:function (result){  
        alert(result);  
      }  
   });  
}  

后端代碼:
如方法一潮饱,不變。

無刷新的上傳圖片功能赏陵,也輕松的搞定了饼齿!

總結(jié)

一般根據(jù)業(yè)務(wù)選擇對應(yīng)的方式來實現(xiàn),文章里面主要是告訴大家如何實現(xiàn)蝙搔,一些細節(jié)處理缕溉,還是需要大家自己去處理。
如有疑問或者建議吃型,都可以聯(lián)系我证鸥。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市勤晚,隨后出現(xiàn)的幾起案子枉层,更是在濱河造成了極大的恐慌,老刑警劉巖赐写,帶你破解...
    沈念sama閱讀 206,013評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件鸟蜡,死亡現(xiàn)場離奇詭異,居然都是意外死亡挺邀,警方通過查閱死者的電腦和手機揉忘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,205評論 2 382
  • 文/潘曉璐 我一進店門跳座,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人泣矛,你說我怎么就攤上這事疲眷。” “怎么了您朽?”我有些...
    開封第一講書人閱讀 152,370評論 0 342
  • 文/不壞的土叔 我叫張陵狂丝,是天一觀的道長。 經(jīng)常有香客問我哗总,道長几颜,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,168評論 1 278
  • 正文 為了忘掉前任魂奥,我火速辦了婚禮菠剩,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘耻煤。我一直安慰自己,他們只是感情好准颓,可當(dāng)我...
    茶點故事閱讀 64,153評論 5 371
  • 文/花漫 我一把揭開白布哈蝇。 她就那樣靜靜地躺著,像睡著了一般攘已。 火紅的嫁衣襯著肌膚如雪炮赦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 48,954評論 1 283
  • 那天样勃,我揣著相機與錄音吠勘,去河邊找鬼。 笑死峡眶,一個胖子當(dāng)著我的面吹牛剧防,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播辫樱,決...
    沈念sama閱讀 38,271評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼峭拘,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了狮暑?” 一聲冷哼從身側(cè)響起鸡挠,我...
    開封第一講書人閱讀 36,916評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎搬男,沒想到半個月后拣展,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,382評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡缔逛,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,877評論 2 323
  • 正文 我和宋清朗相戀三年备埃,在試婚紗的時候發(fā)現(xiàn)自己被綠了溜腐。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 37,989評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡瓜喇,死狀恐怖挺益,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情乘寒,我是刑警寧澤望众,帶...
    沈念sama閱讀 33,624評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站伞辛,受9級特大地震影響烂翰,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蚤氏,卻給世界環(huán)境...
    茶點故事閱讀 39,209評論 3 307
  • 文/蒙蒙 一甘耿、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧竿滨,春花似錦佳恬、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,199評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至贰剥,卻和暖如春倾剿,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蚌成。 一陣腳步聲響...
    開封第一講書人閱讀 31,418評論 1 260
  • 我被黑心中介騙來泰國打工前痘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人担忧。 一個月前我還...
    沈念sama閱讀 45,401評論 2 352
  • 正文 我出身青樓芹缔,卻偏偏與公主長得像,于是被迫代替她去往敵國和親涵妥。 傳聞我的和親對象是個殘疾皇子乖菱,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,700評論 2 345

推薦閱讀更多精彩內(nèi)容