使用第三方插件 formidable 处理表单数据/文件

Express 4 以前,我们通常使用 req.files 来对请求中的文件进行处理,但在 Express 4 中这种用法已经被抛弃,默认情况下 req.filesreq 对象上不再可用。官方推荐我们使用第三方中间件。

在这里我们使用第三方中间件 formidable,可用于解析表单数据和上传的文件。以下是基本使用:

var formidable = require('formidable')app.post('/upload', (req, res, next) => {var form = new formidable.IncomingForm()form.parse(req, (err, fields, files) => {if(err) return next(err)console.log(fields) //Object 表单数据console.log(files) //上传文件用files.<name>访问res.json({ code: 1, message: 'upload success' })})
})

Element-ui -- upload 上传组件

前端框架使用Vue2, 以头像上传为例。

<el-upload :action="$apiURL + '/upload'" <!--后台上传地址--> :data="uploadData" <!--需要传到后台的附加数据 我这里把用户名传了过去-->:show-file-list="false" :on-success="getAvatarSuccess" <!--上传成功回调--> :before-upload="beforeAvatarUpload"> <!--上传前调用的钩子--> <img :src="$imageURL + avatar" class="avatar" />
</el-upload>
export default {data(){return {avatar: '', //头像文件名 使用时需要拼接形成完整路径uploadData: {//使用 vuex 将用户名放在了 state 中 便于存取name: this.$store.state.username}}},methods: {getAvatarSuccess(res, file) {// res是响应数据 file是文件信息this.avatar = res.avatarconsole.log(res) // 本例中是  { avatar: 'xxx.jpg' }},beforeAvatarUpload(file) {const isJPG = file.type === 'image/jpeg'const isLt2M = file.size / 1024 / 1024 < 2if (!isJPG) {this.$message.error('上传头像图片只能是 JPG 格式!')}if (!isLt2M) {this.$message.error('上传头像图片大小不能超过 2MB!')}//返回 true 时进行请求上传return isJPG && isLt2M }}
}

Express 中使用 formidable 处理请求做出响应

app.post('/upload', (req, res, next) => {let form = new formidable.IncomingForm()form.encoding = 'utf-8' // 编码form.keepExtensions = true // 保留扩展名form.uploadDir = path.join(__dirname, '../public/images/') //文件存储路径 最后要注意加 '/' 否则会被存在public下form.parse(req, (err, fileds ,files) => { // 解析 formData 数据if(err) return next(err) let username = fileds.name //用户名 用于修改用户头像路径let oldPath = files.file.path //获取文件路径 ~/public/images/<随机生成的文件名>.<扩展名>let imgname = files.file.name //前台上传时的文件名 也就是文件原本的名字let userImgname = imgname.replace(/[^.]+/, username) //把扩展名前的文件名给替换掉//我这里为了方便存储 统一将文件名改为 <用户名>.jpglet newPath = path.join(path.dirname(oldPath), userImgname) fs.rename(oldPath, newPath, (err) => {if(err) return next(err)Model.User.updateOne({ name: username },  //更新用户的avatar属性{ avatar: userImgname }, err => {if(err) return next(err)res.json({ avatar: userImgname })                     })})})
})

转载于:https://www.cnblogs.com/qimeng/p/9552275.html

Express + Element-ui 实现图片/文件上传相关推荐

  1. element ui upload组件文件上传一次 后,不论是上传成功之后修改文件再上传还是上传失败重新上传,再次点击上传均无反应。

    问题: Element UI Upload 组件文件上传一次 后,不论是上传成功之后修改文件再上传还是上传失败重新上传,再次点击上传均无反应. 原因: 第一次上传文件后,浏览器还保存着我们已经上传的文 ...

  2. axios文件上传 formdata_基于业务场景下的图片/文件上传方案总结

    图片/文件上传组是企业项目开发中必不可少的环节之一, 但凡涉及到用户模块的都会有图片/文件上传需求, 在很多第三方组件库(ant desigin, element ui)中它也是基础组件之一. 接下来 ...

  3. 前端基于element组件的语音文件上传

    前端基于element组件的语音文件上传 原理 项目采用的是element组件的UI库,基于标签,实现基本的文件上传功能,并基于标签内置的触发事件,实现了对语音文件大小,格式,上传前确认,上传后显示已 ...

  4. .Net Core 图片文件上传下载

    当下.Net Core项目可是如雨后春笋一般发展起来,作为.Net大军中的一员,我热忱地拥抱了.Net Core并且积极使用其进行业务的开发,我们先介绍下.Net Core项目下实现文件上传下载接口. ...

  5. Office文档上传后实时转换为PDF格式_图片文件上传后实时裁剪_实现在线预览Office文档

    Office文档上传后实时转换为PDF格式_图片文件上传后实时裁剪 前置条件 安装LibreOffice 安装OpenOffice 安装Unoconv 安装ImageMagick.x86_64 安装G ...

  6. springmvc图片文件上传接口

    springmvc图片文件上传 用MultipartFile文件方式传输 Controller package com.controller;import java.awt.image.Buffere ...

  7. UI upload多文件上传

    UI upload多文件上传 cs: using System; using System.Collections; using System.ComponentModel; using System ...

  8. php是视频还是图片格式,php 视频、音频和图片文件上传,该如何解决

    PHP code<?php ob_start(); $uploadDir = dirname(__FILE__).'/upload'; //自动创建目录 if(!file_exists($upl ...

  9. Java实现图片文件上传

    Java实现图片文件上传 Java实现后台图片上传,将上传图片的接口进行分层,便于维护接口. 接口部分(interface) 将接口分为单图片上传以及多图片上传 public interface Fi ...

  10. php中图片文件上传,显示缩略图

    php中图片文件上传,显示缩略图 htm代码块: <meta charset="utf-8" /> <style>img {max-width: 100px ...

最新文章

  1. Redis的字典扩容与ConcurrentHashMap的扩容策略比较
  2. BZOJ4563[Haoi2016]放棋子
  3. 荣登2019中国“十佳大数据案例”,腾讯大数据再获国家认可
  4. java程序启动命令_如何用java启动windows命令行程序
  5. Android系统--Binder系统具体框架分析(一)补充
  6. 领扣-1/167 两数之和 Two Sum MD
  7. 使用Python爬虫爬取网络美女图片
  8. vue 声明周期函数_vue-router路由守卫-上
  9. 百度智能云发布『乘风』 端云一体化方案 助力人脸应用10分钟落地
  10. mysql_query 资源标识符_PHP mysql_query() 函数解析
  11. Qt5开发从入门到精通——第一篇概述
  12. 声卡调试精调效果都用那些宿主(DAW)机架和效果器插件
  13. 石光荣,黑客帝国,社会化网络----社会化网络能否平衡抽象主导的现代生活? (发表于程序员第一期)
  14. 【CSDN浏览器助手】这款插件忒好用了
  15. vue axios实战,请求天气预报接口
  16. 电信网上营业厅用户自服务系统的设计与实现
  17. 调整物料的存货科目代码,会不会造成存货系统和总账对账不平?
  18. 离散数学程序实践——判断是否(反)自反,(反)对称,可传递——c
  19. 视频剪辑教程自学技巧:关于正确的短视频剪辑流程分享
  20. boostraptable 表格数据未刷新

热门文章

  1. super在python3和python2_Python扩展与 – 使用super()python 3 vs python 2
  2. 机械硬盘 mysql调优_【MYSQL】使用RAID增加传统机器硬盘的性能
  3. python找零钱问题_Python基于回溯法子集树模板解决找零问题示例
  4. 图论--2-SAT--HDOJ/HDU 1824 Let's go home
  5. maven profile实现多环境构建 (单项目多套配置)
  6. [kubernetes] kubectl proxy 让外部网络访问K8S service的ClusterIP
  7. 纯c语言实现动态分配多维数组的方法
  8. 解决 Gedit 中文乱码
  9. Advanced Bash-Scripting Guide 学习笔记一
  10. Eigen入门之密集矩阵 10 - 矩阵的行优先及列优先存储