鍍金池/ 問答/C  數(shù)據(jù)庫  HTML/ node.js接收上傳圖片,將圖片信息寫入數(shù)據(jù)庫與解析form數(shù)據(jù)完成時向前臺發(fā)

node.js接收上傳圖片,將圖片信息寫入數(shù)據(jù)庫與解析form數(shù)據(jù)完成時向前臺發(fā)送數(shù)據(jù)異步的問題

后臺接收前臺傳來的form表單數(shù)據(jù),數(shù)據(jù)為圖片。用的是formidable這個插件,然后經(jīng)過處理后寫入數(shù)據(jù)庫,在form.on('end')的時候,再把數(shù)據(jù)庫的圖片數(shù)據(jù)返回給前臺,問題就出在這了,往數(shù)據(jù)庫插入數(shù)據(jù)是異步的動作,form.on('end')的時候數(shù)據(jù)不一定插進去了,如果在插入成功的回調(diào)內(nèi)發(fā)送數(shù)據(jù),單圖可以,多圖因為循環(huán),就會報錯:can't set headers after they are sent
現(xiàn)在想到的解決辦法是在form.on('end')內(nèi)寫個定時器,等一會再發(fā)送,可是這樣不穩(wěn)定,誰知道這段特定時間后,數(shù)據(jù)有沒有插入完成呢

clipboard.png

回答
編輯回答
吢丕

使用 event (http://nodejs.cn/api/events.html)自定義事件并監(jiān)聽即可,數(shù)據(jù)庫都操作完成再觸發(fā)事件向前端傳輸數(shù)據(jù)。

2018年1月18日 02:26
編輯回答
心悲涼

異步編程的難度就在這些地方,一個動作的開始要依賴其他的動作完成作為標(biāo)記。而你的邏輯就是:

  1. 所有圖片上傳
  2. 1完成后開始查詢數(shù)據(jù)庫
  3. 2完成后給res返回數(shù)據(jù)

所以流程上面看起來跟form.on('end')好像沒有任何關(guān)系,為什么要在這個事件里面做操作?
另外我不明白的一點是要返回給客戶端的到底是什么,latestFileData?那Upload.find({}...)查出來的又是什么?
res.json只能調(diào)用一次,如果你兩者都想返回,那必須等結(jié)果都就緒后合成一個json再調(diào)用。
類似的流程在NodeJS里面以后還會經(jīng)常遇到,根本的解決方式是使用一些流程控制的庫,我比較常用的有2個:

  1. async,你需要使用的是parallel或是parallelLimit,就是一系列可以并行的任務(wù)都完成后觸發(fā)一個回調(diào),這時候你就可以用res.json了;
  2. Bluebird,需要使用Promise.all,原理同上,語法上不太一樣。

文檔和習(xí)慣上面?zhèn)€人更喜歡前者。不管哪一個都會了async/await,這是最新的標(biāo)準(zhǔn),也是以后的方向,建議早些了解。

2017年12月1日 18:41
編輯回答
情未了

這個簡單的,把異步轉(zhuǎn)為同步

2018年2月17日 21:53