Express系列之multer

这两天在看《nodejs权威指南》,这本书看了很久了,可是读的一直不细,此次才好好看了一遍。html

收获仍是蛮多的,主要在于wenpack使用的一些细节问题,有点茅塞顿悟的体验吧,另外在node上也再也不一脸懵逼了。不过说实话,以如今的水平向直接使用node作点什么仍是挺难的,今天测试了下连接mongodbmysql数据库,虽然能使用,但仍是怪怪的。因此就想先使用现有的框架,再反推学习node。node

框架的话就选了这个express.mysql

主要就是测试了几个书里提到的中间件,书写的有些早,不少api都过期了,照着官网一点一点找更新的地方看。jquery

目前以为对我有用的是:multerstaticajax

后者能够在本地调试页面,对于手机页面尤为有用。sql

此次主要说一下multer,我并无实现全部的功能,只是实现单图片上传这一个功能,其余的再摸索喽。mongodb

这是文件的整个目录,主要就两个,一个是根目录下的main.js,还有一个是public/index.html数据库

放代码:express

//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="" alt="" 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的对象中,传给后台。api

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()做为每张图片不一样的识别符,这样就不会再出现覆盖的状况。

目前就这样,下次弄出来了多图片上传我再接着更新。

相关文章
相关标签/搜索