使用formidable模塊包裝POST請求

準(zhǔn)備

使用 $npm install http-f2e-server@0.0.6 進(jìn)行安裝之前版本,本篇在此基礎(chǔ)上使得POST請求的文件數(shù)據(jù)處理結(jié)果類似GET請求。

添加formidable依賴

修改package.json文件添加formidable依賴。由于之前版本忘記添加underscore依賴,本次加上結(jié)果如下:

"dependencies": {
    "mime": "1.2.11",
    "underscore": "1.7.0",
    "formidable": ">=1.0.15"
},

npm install

安裝formidable。

主流程添加入口

if( req.method === "POST" ){    // POST請求
    rs.on("end",function(){
        require("./lib/post").execute(str, root, req, resp);
    });
}

將resp傳遞進(jìn)去以備操作輸出給客戶端。

創(chuàng)建formidable對象并且解析request

var form = new formidable.IncomingForm(),
    files = [],
    fields = {};
form.uploadDir = req.data.uploadUrl 
    ? ( root + "/" + req.data.uploadUrl + "/" ) 
    : path.join( __dirname + "/tmpl/" ); //上傳路徑?jīng)]有傳遞的時候, 默認(rèn)
form.parse(req);

在解析事件中添加字段和文件

如果是空文件,不保存

form.on('field', function(field, value) { //處理字段
    fields[field] = value;
}).on('file', function(field, file) {   //處理文本
    if( file.size ){
        files.push({name: field, file: file});
    }
})

解析完成時:

對上傳文件進(jìn)行重命名,同時POST數(shù)據(jù)結(jié)果綁定在request上。

form.on('end', function() {   //字段和文本都保存結(jié)束后
    files.map(function(file){
        fs.rename(file.file.path, form.uploadDir + file.file.name, function (err) {
            if(err){ throw err; }
        });
    });
    req.post = fields; //字段保存在request.post上, 可以在模板頁面使用
    req.files = files; //文件基本信息也保存在request.files上
    resp.end( _.template(str)({require: require,request:req,response:resp}) ); 
});

測試Demo

<fieldset>
    <lengend>表單提交</lengend>
    <form action="post.json" method="post" enctype="multipart/form-data">
        <label>用戶名:</label> <input type="text" name="name"> <br>
        <label>頭像上傳:</label> <input type="file" name="icon"> <br>
        <input type="submit" value="提交">
    </form>
</fieldset>

目標(biāo)代碼 example/post.json

<%=JSON.stringify({
    get: request.data,
    post: request.post,
    files: request.files
})%>

結(jié)果

post.png

PS:

相關(guān)完整代碼已經(jīng)發(fā)布到了npm倉庫中, 可以使用 $npm install http-f2e-server@0.0.8 進(jìn)行安裝或者更新。進(jìn)入目錄后使用 $node http-f2e-server.js 啟動服務(wù),并查看Demo。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,695評論 19 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,326評論 25 708
  • 一師姐過生日,我們鬧得很晚才回來,本來很開心的事,總能隱約的覺察到她一絲絲愁意,是的,往年的生日,都有她老公陪在身...
    Zendy閱讀 259評論 2 5
  • 早上好!#幸福實(shí)修#~每天進(jìn)步1%#幸福實(shí)修12班-02-駱金芳--富陽# 20170930(5/60) 【幸福三...
    幸福實(shí)修金芳閱讀 346評論 0 2
  • 剛剛看了一篇關(guān)于簡述楊絳先生一生的微博,感觸很深,且解決了一些的心中疑問: 1.如何保持一生不變?每當(dāng)躊然,回望初...
    懷山柔水閱讀 692評論 0 0

友情鏈接更多精彩內(nèi)容