91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

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

發布時間:2021-07-24 11:26:18 來源:億速云 閱讀:159 作者:小新 欄目:web開發

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

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

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,總的來說應該沒什么難的,總之就是點擊按鈕選擇完圖片之后,會將圖片的信息放在一個鍵名為myfile的對象中,傳給后臺。

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

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

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

我在向前臺返回數據的時候

res.send(req.file)

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

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設置的是文件的名字,那在這里如果寫成這種:

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

你會發現你傳入的每一張圖片的名字都是myfile.png,新的覆蓋舊的。所以為了能保存傳入的所有圖片,我就使用Date.now()作為每張圖片不同的識別符,這樣就不會再出現覆蓋的情況。

以上是“Express系列之multer上傳的用法示例”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宝丰县| 阳新县| 青海省| 长兴县| 沂南县| 五莲县| 台东市| 富宁县| 黄山市| 榆中县| 碌曲县| 高邮市| 佛山市| 澄城县| 商都县| 三台县| 塔城市| 安徽省| 澄迈县| 永靖县| 海晏县| 宜良县| 金昌市| 尚志市| 新巴尔虎左旗| 浏阳市| 常德市| 仪陇县| 中方县| 武汉市| 岑溪市| 浦江县| 高淳县| 得荣县| 英超| 盐源县| 蛟河市| 乌恰县| 铜陵市| 汉阴县| 报价|