NodeJS+axios上传图片

前端js部分

changeEvent (e) {   ------  //change事件方法
   let oFile = e.target.files[0]  ------  //获取文件对象
   let param = new FormData()  ------  //new一个formData
   param.append('file', oFile, oFile.name)   ------  //将文件添加到formdata中
   param.append('chunk', '0') 
   let config = {
          headers: {'Content-Type': 'multipart/form-data'}
    }
   this.axios.post('/api/upload/upavatar?username=' + username, param, config) ------//传输数据
          .then(response => {
            if (response.data.data === 1) {  ------ //成功后的回掉
              let instance = Toast({
                message: '头像更改成功'
              })
              setTimeout(() => {
                instance.close()
              }, 1000)
            }
          })

}

  

NodeJS部分

需要引入formidable、path模块

router.post('/upavatar', function (req, res, next) {
  var form = new formidable.IncomingForm()
  form.uploadDir = path.normalize(__dirname + '/../public/images/avatar') ------图片上传目录
  form.parse(req, function (err, fields, files) {
    var oldpath = files.file.path
    var newpath = path.normalize(__dirname + '/../public/images/avatar') + '\\' + req.query.username + '.png'    -------//给上传的图片重命名
    fs.rename(oldpath, newpath, function (err) {
      if (err) {
        res.send('-1')
        return
      }
      if (newpath) {
        let avatarPath = 'server/public/images/avatar/' + req.query.username + '.png'  ------//存入数据库的图片地址(相对于页面)
        db.updateMany('users', {'username': req.query.username}, {$set: {avatar: avatarPath}}, function (err, result) {  ------//更新数据库的头像地址
          if (err) {
            res.send('-2')
            return
          }
          res.json({data: 1})
        })
      }
    })
  })
})

  

转载于:https://www.cnblogs.com/wangxiayun/p/8116896.html

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值