Mrcdh技术博客 Mrcdh技术博客
首页
  • Html5
  • Javascript
  • Nodejs
  • electron
  • Android
  • 微信公众号
  • 框架
  • 其他
  • Mysql
  • PHP
  • Python
  • java
  • Gulp
  • 其它
  • 网站
  • 资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Mrcdh

全栈开发小学生
首页
  • Html5
  • Javascript
  • Nodejs
  • electron
  • Android
  • 微信公众号
  • 框架
  • 其他
  • Mysql
  • PHP
  • Python
  • java
  • Gulp
  • 其它
  • 网站
  • 资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • Html5

  • JavaScript

  • Nodejs

  • express

    • express默认日志组件morgan
    • express基本使用
    • express路由
    • Express + Element-ui 实现图片&文件上传
    • express常见问题
  • electron

  • Android

  • 微信公众号

  • 框架

  • 其他

  • selenium

  • Sequelize

  • 大前端
  • express
mrcdh
2022-04-29

Express + Element-ui 实现图片&文件上传

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

在这里我们使用第三方中间件 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' })
  })
})
1
2
3
4
5
6
7
8
9
10
11

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.avatar
      console.log(res) // 本例中是  { avatar: 'xxx.jpg' }
    },
    beforeAvatarUpload(file) {
      const isJPG = file.type === 'image/jpeg'
      const isLt2M = file.size / 1024 / 1024 < 2
      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      //返回 true 时进行请求上传
      return isJPG && isLt2M 
    }
  }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38

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) //把扩展名前的文件名给替换掉
    //我这里为了方便存储 统一将文件名改为 <用户名>.jpg
    let 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 })                
       })
    })
  })
})
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#express
上次更新: 2023/09/22, 16:54:32
express路由
express常见问题

← express路由 express常见问题→

最近更新
01
uniapp常见问题
03-19
02
Vue3项目搭建
12-25
03
使用pnpm的monorepo组织项目
11-01
更多文章>
Theme by Vdoing | Copyright © 2020-2025 Mrcdh | 苏ICP备2020058908号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×