Express系列之multer上傳的用法示例

小編給大家分享一下Express系列之multer上傳的用法示例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)是一家以重慶網(wǎng)站建設(shè)公司、網(wǎng)頁(yè)設(shè)計(jì)、品牌設(shè)計(jì)、軟件運(yùn)維、成都網(wǎng)站營(yíng)銷(xiāo)、小程序App開(kāi)發(fā)等移動(dòng)開(kāi)發(fā)為一體互聯(lián)網(wǎng)公司。已累計(jì)為門(mén)窗定制等眾行業(yè)中小客戶(hù)提供優(yōu)質(zhì)的互聯(lián)網(wǎng)建站和軟件開(kāi)發(fā)服務(wù)。

主要說(shuō)一下multer,我并沒(méi)有實(shí)現(xiàn)所有的功能,只是實(shí)現(xiàn)單圖片上傳這一個(gè)功能,其他的再摸索嘍。

Express系列之multer上傳的用法示例

這是文件的整個(gè)目錄,主要就兩個(gè),一個(gè)是根目錄下的main.js,還有一個(gè)是public/index.html。

放代碼:

//main.js
let express = require('express');

var multer = require('multer')

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
   cb(null, 'public/');
  },
  filename: function (req, file, cb) {
   cb(null, Date.now() + '.png');
  }
 })
 
var upload = multer({ storage: storage })

//var upload = multer({ dest: 'public/' })
 

let app = express()

app.use(express.static('public'))

app.post('/public/index.html',upload.single('myfile'),(req,res,next)=>{
  console.log(req.file)
  res.send(req.file)
})

app.listen(3300,'127.0.0.1')
<!-- index.html -->

<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>

<body>
  <input type="file" id="file" accept="image/*">
  <div id="result"></div>
  <img src=""  id="img" width="40" height="40">
  <script>
    let file = document.getElementById('file');
    file.onchange = function (e) {
      let file = e.target.files[0];
      let xhr = new XMLHttpRequest();
      let fd = new FormData();
      fd.append('myfile', file)
      xhr.open('post', '/public/index.html')
      xhr.onload = function () {
        // console.log(xhr)
        if (xhr.status === 200) {
          let data = JSON.parse(xhr.responseText)
          document.getElementById('result').innerHTML = this.response
          document.getElementById('img').src = data.filename
        }
      }
      xhr.send(fd)
    }
  </script>
</body>

</html>

不想引用jquery庫(kù),我就原生寫(xiě)的ajax,總的來(lái)說(shuō)應(yīng)該沒(méi)什么難的,總之就是點(diǎn)擊按鈕選擇完圖片之后,會(huì)將圖片的信息放在一個(gè)鍵名為myfile的對(duì)象中,傳給后臺(tái)。

express把接受到的圖片存儲(chǔ)在/public/文件下,這里有個(gè)小小的坑??梢钥吹轿以?code>main.js注釋了這樣一行代碼:

var upload = multer({ dest: 'public/' })

其實(shí)最開(kāi)始的時(shí)候我用的就是這一行代碼,dest的意思是選擇一個(gè)路徑去存儲(chǔ)文件,但是這樣寫(xiě)有一個(gè)小小的問(wèn)題,存入進(jìn)來(lái)的文件是沒(méi)有后綴名的。

我在向前臺(tái)返回?cái)?shù)據(jù)的時(shí)候

res.send(req.file)

這個(gè)問(wèn)題就很?chē)?yán)重,比如一個(gè)場(chǎng)景是我上傳一張圖片做頭像,但是等我下次進(jìn)入自己的個(gè)人頁(yè)面,后臺(tái)給我返回的數(shù)據(jù)沒(méi)有辦法作為圖片的地址使用,這就很麻煩了。所以在網(wǎng)上找了一個(gè)原因,就把上面的代碼注釋換成了這個(gè):

var storage = multer.diskStorage({
  destination: function (req, file, cb) {
   cb(null, 'public/');
  },
  filename: function (req, file, cb) {
   cb(null, Date.now() + '.png');
  }
})

var upload = multer({ storage: storage })

destination是文件存儲(chǔ)的地址,filename設(shè)置的是文件的名字,那在這里如果寫(xiě)成這種:

filename: function (req, file, cb) {
 cb(null, file.fieldname + '.png');
}

你會(huì)發(fā)現(xiàn)你傳入的每一張圖片的名字都是myfile.png,新的覆蓋舊的。所以為了能保存?zhèn)魅氲乃袌D片,我就使用Date.now()作為每張圖片不同的識(shí)別符,這樣就不會(huì)再出現(xiàn)覆蓋的情況。

以上是“Express系列之multer上傳的用法示例”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

分享文章:Express系列之multer上傳的用法示例
網(wǎng)頁(yè)URL:http://muchs.cn/article8/ihihop.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供營(yíng)銷(xiāo)型網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站關(guān)鍵詞優(yōu)化、外貿(mào)網(wǎng)站建設(shè)移動(dòng)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站網(wǎng)頁(yè)設(shè)計(jì)