multer上传如何使用

这次给大家带来multer上传如何使用,multer上传使用的注意事项有哪些,下面就是实战案例,一起来看一下。

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

框架的话就选了这个express.

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

目前觉得对我有用的是:multer和static。

后者可以在本地调试页面,对于手机页面尤其有用。

这次主要说一下multer,我并没有实现所有的功能,只是实现单图片上传这一个功能,其他的再摸索喽。

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

放代码:

//main.jslet 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')

登录后复制

        Document    

multer上传如何使用 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) }

登录后复制

不想引用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()作为每张图片不同的识别符,这样就不会再出现覆盖的情况。

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

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

BootStrap的文本编辑器组件Summernote使用详解

操作search组件在键盘显示

jquery提交数组数据用springmvc接收的方法

以上就是multer上传如何使用的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2771908.html

(0)
上一篇 2025年3月8日 13:06:23
下一篇 2025年3月8日 13:06:31

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • 在vue2中使用ref步奏详解

    这次给大家带来在vue2中使用ref步奏详解,在vue2中使用ref的注意事项有哪些,下面就是实战案例,一起来看一下。 本文介绍了vue2里面ref的具体使用方法,分享给大家,具体如下。 1、我们先定义两个组件 html部分 登录后复制 j…

    编程技术 2025年3月8日
    200
  • 开源JS插件框架MinimaJS使用介绍

    这次给大家带来开源JS插件框架MinimaJS使用介绍,开源JS插件框架MinimaJS使用的注意事项有哪些,下面就是实战案例,一起来看一下。 MinimaJS,完全开源,源码下载地址:https://github.com/lorry201…

    编程技术 2025年3月8日
    200
  • JS模块模式使用详解

    这次给大家带来JS模块模式使用详解,JS模块模式使用的注意事项有哪些,下面就是实战案例,一起来看一下。 在JS中没有Class的概念,那么如何体现Object的Public和Private属性呢,答案就是模块模式(Module Patter…

    编程技术 2025年3月8日
    200
  • angular cli的使用详解

    这次给大家带来angular cli的使用详解,angular cli使用的注意事项有哪些,下面就是实战案例,一起来看一下。 背景介绍 关于Angular版本,Angular官方已经统一命名Angular 1.x同一为Angular JS;…

    编程技术 2025年3月8日
    200
  • Three.js使用详解

    这次给大家带来Three.js使用详解,Three.js使用的注意事项有哪些,下面就是实战案例,一起来看一下。 开场白 webGL可以让我们在canvas上实现3D效果。而three.js是一款webGL框架,由于其易用性被广泛应用。如果你…

    编程技术 2025年3月8日
    200
  • Particles.js库在vue里如何使用

    这次给大家带来Particles.js库在vue里如何使用,Particles.js库在vue里使用的注意事项有哪些,下面就是实战案例,一起来看一下。 知乎的首页后面的粒子动效总觉得很炫酷,搜了一下,发现是用particles.js编写的。…

    编程技术 2025年3月8日
    200
  • Vue-router的路由元信息使用详解

    这次给大家带来Vue-router的路由元信息使用详解,Vue-router路由元信息使用的注意事项有哪些,下面就是实战案例,一起来看一下。 一、背景 之前写前端都是后端返回界面,跳转神马的完全不用自己操心,但是这次用 vue 写的前端,第…

    编程技术 2025年3月8日
    200
  • Vue-Router的滚动行为使用详解

    这次给大家带来Vue-Router的滚动行为使用详解,Vue-Router滚动行为使用的注意事项有哪些,下面就是实战案例,一起来看一下。 滚动行为 使用前端路由,当切换到新路由时,想要页面滚到顶部,或者是保持原先的滚动位置,就像重新加载页面…

    编程技术 2025年3月8日
    200
  • angularJS+Ionic在移动端进行图片上传(附代码)

    这次给大家带来angularJS+Ionic在移动端进行图片上传(附代码),angularJS+Ionic在移动端进行图片上传的注意事项有哪些,下面就是实战案例,一起来看一下。 前端开发中经常会碰到图片上传的问题,网上的解决办法很多,可是有…

    编程技术 2025年3月8日
    200
  • JS面向对象的使用详解

    这次给大家带来JS面向对象的使用详解,JS面向对象使用的注意事项有哪些,下面就是实战案例,一起来看一下。 数据类型 在JavaScript中,数据类型分为两类: 原始类型 保存一些简单数据,如true,5等。JavaScript共有5中原始…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论