欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

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

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

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

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

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

這是文件的整個目錄,主要就兩個,一個是根目錄下的main.js,還有一個是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庫,我就原生寫的ajax,總的來說應(yīng)該沒什么難的,總之就是點擊按鈕選擇完圖片之后,會將圖片的信息放在一個鍵名為myfile的對象中,傳給后臺。

express把接受到的圖片存儲在/public/文件下,這里有個小小的坑。可以看到我在main.js注釋了這樣一行代碼:

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

其實最開始的時候我用的就是這一行代碼,dest的意思是選擇一個路徑去存儲文件,但是這樣寫有一個小小的問題,存入進(jìn)來的文件是沒有后綴名的。

我在向前臺返回數(shù)據(jù)的時候

res.send(req.file)

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

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是文件存儲的地址,filename設(shè)置的是文件的名字,那在這里如果寫成這種:

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

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

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

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

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

廣告

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

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