Node.js的文件上傳

0.目標

在Express中實現(xiàn)單文件上傳。

【參考代碼】


1.部署Express

如果不知道如何部署,可參照: 部署Express


2.服務器端

這里要用到multer中間件,這個需要自行安裝:

npm install multer --save

在routes/index.js中引用multer,另外叶眉, 因為需要用到文件系統(tǒng)址儒,所以還要引用fs模塊:

var multer  = require('multer');
var fs = require("fs");

增加一個路由,用來顯示頁面:

/* 瀏覽器輸入地址(如127.0.0.1:3000/upload)后衅疙,顯示views/upload頁面莲趣,此頁面使用默認引擎(這里是jade)渲染 */
router.get('/upload', function(req, res, next) {
  res.render('upload', {msg: "請先上傳"});
});

增加一個路由,用來處理上傳操作:

var upload = multer({ dest: '/tmp/' })
router.post('/file_upload', upload.array('image'), function(req, res, next) {

    console.log(req.files[0]);  // 上傳的文件信息
    if(undefined == req.files[0])
    {
        res.end( JSON.stringify( {message:"文件不存在饱溢!"} ) );
    }
    
    var response = {};

    var des_file = "./files/" + req.files[0].originalname;
    fs.readFile( req.files[0].path, function (err, data) {
        fs.writeFile(des_file, data, function (err) {
            if( err ){
                console.log( err );
                response = {
                    message:'File uploaded failed', 
                    filename:err
                };
            }else{
                response = {
                    message:'File uploaded successfully', 
                    filename:req.files[0].originalname
                };
            }
            console.log( response );
            res.end( JSON.stringify( JSON.stringify( response ) ) );
        });
    });
});

注意
在根目錄下創(chuàng)建一個文件夾喧伞,名稱是files。如果沒有先創(chuàng)建绩郎,上傳文件時會報錯潘鲫。


3.客戶端頁面

在views文件夾下,添加一個文件upload.jade

doctype html
html
    head
        title= title
        link(rel='stylesheet', href='/stylesheets/style.css')
    body
        h1 Express的文件上傳
        h3 選擇一個文件上傳
            form(action="/file_upload" method="post" enctype="multipart/form-data")
                input(type="file" name="image" size="50")
                input(type="submit" value="上傳文件")
        
        h3 消息:#{msg}

4.測試

運行服務肋杖,在瀏覽器里輸入:

http://127.0.0.1:3000/upload

瀏覽器中選擇一個文件上傳:

選擇上傳文件

上傳結果:


上傳文件的結果

服務端打痈嚷亍:

服務端打印

原創(chuàng)文章,未經(jīng)許可状植,請勿轉載
作者:Mike的讀書季
日期:2016.09.19
QQ:1139904786
Blog:http://blog.csdn.net/kkdestiny

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末彼念,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子浅萧,更是在濱河造成了極大的恐慌逐沙,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,576評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件洼畅,死亡現(xiàn)場離奇詭異吩案,居然都是意外死亡,警方通過查閱死者的電腦和手機帝簇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,515評論 3 399
  • 文/潘曉璐 我一進店門徘郭,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人丧肴,你說我怎么就攤上這事残揉。” “怎么了芋浮?”我有些...
    開封第一講書人閱讀 168,017評論 0 360
  • 文/不壞的土叔 我叫張陵抱环,是天一觀的道長。 經(jīng)常有香客問我纸巷,道長镇草,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,626評論 1 296
  • 正文 為了忘掉前任瘤旨,我火速辦了婚禮梯啤,結果婚禮上,老公的妹妹穿的比我還像新娘存哲。我一直安慰自己因宇,他們只是感情好七婴,可當我...
    茶點故事閱讀 68,625評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著察滑,像睡著了一般本姥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上杭棵,一...
    開封第一講書人閱讀 52,255評論 1 308
  • 那天婚惫,我揣著相機與錄音,去河邊找鬼魂爪。 笑死先舷,一個胖子當著我的面吹牛,可吹牛的內容都是我干的滓侍。 我是一名探鬼主播蒋川,決...
    沈念sama閱讀 40,825評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼撩笆!你這毒婦竟也來了捺球?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 39,729評論 0 276
  • 序言:老撾萬榮一對情侶失蹤夕冲,失蹤者是張志新(化名)和其女友劉穎氮兵,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體歹鱼,經(jīng)...
    沈念sama閱讀 46,271評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡泣栈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,363評論 3 340
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了弥姻。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片南片。...
    茶點故事閱讀 40,498評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖庭敦,靈堂內的尸體忽然破棺而出疼进,到底是詐尸還是另有隱情,我是刑警寧澤秧廉,帶...
    沈念sama閱讀 36,183評論 5 350
  • 正文 年R本政府宣布伞广,位于F島的核電站,受9級特大地震影響定血,放射性物質發(fā)生泄漏赔癌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,867評論 3 333
  • 文/蒙蒙 一澜沟、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧峡谊,春花似錦茫虽、人聲如沸刊苍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,338評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽正什。三九已至,卻和暖如春号杏,著一層夾襖步出監(jiān)牢的瞬間婴氮,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,458評論 1 272
  • 我被黑心中介騙來泰國打工盾致, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留主经,地道東北人。 一個月前我還...
    沈念sama閱讀 48,906評論 3 376
  • 正文 我出身青樓庭惜,卻偏偏與公主長得像罩驻,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子护赊,可洞房花燭夜當晚...
    茶點故事閱讀 45,507評論 2 359

推薦閱讀更多精彩內容