我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么利用nodeJS+vue图片上传实现更新头像

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么利用nodeJS+vue图片上传实现更新头像

本篇内容主要讲解“怎么利用nodeJS+vue图片上传实现更新头像”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用nodeJS+vue图片上传实现更新头像”吧!

思路:

前端通过el-upload将图片传给后端服务,后端通过formidable中间件解析图片,生成图片到静态资源文件夹下(方便前端直接访问),并将图片路径返回给前端,前端拿到图片路径即可渲染头像。

1、前端准备

前端采用vue的el-upload组件,具体用法见官方API。使用代码如下

<!--头像上传--><el-upload  class="avatar-uploader"  action="http://localhost:3007/api/upload"  :data= this.avatarForm  :show-file-list="false"  :on-success="handleAvatarSuccess"  :before-upload="beforeAvatarUpload">  <img v-if="imageUrl" :class="lazy" data-src="imageUrl" class="avatar">  <i v-else class="avatar-uploader-icon">点击修改头像</i></el-upload>

action:必选参数,上传的地址,这里是http://localhost:3007/api/upload 表示后端服务地址

before-upload:上传文件之前的钩子,主要用于文件上传前的校验,可以限制文件上传的大小及格式。这里设置头像只能上传png、jpg格式,图片大小不能超过2M,具体设置方法如下:

beforeAvatarUpload(file) {  console.log(file.type)  const isJPG = file.type === 'image/jpeg'  const isPNG = file.type === 'image/png'  const isLt2M = file.size / 1024 / 1024 < 2  if (!(isJPG || isPNG)) {    this.$message.error('上传头像图片只能是 JPG 格式!')  }  if (!isLt2M) {    this.$message.error('上传头像图片大小不能超过 2MB!')  }  return (isPNG || isJPG) && isLt2M}

on-success:文件上传成功时的钩子,这里接受图片路径成功后,拼接成正确的图片路径,并将路径赋值给class="lazy" data-src,具体如下:

handleAvatarSuccess(res, file) {  if (res.status === '1') return this.$message.error(res.message)  this.imageUrl = `http://localhost:3007/public/${res.class="lazy" data-srcurl}`  //拼接路径  this.$message.success('修改头像成功')}

data:上传时附带的额外参数.这里将用户名、用户ID传给后端服务,用于生成图片时拼接图片名,保证图片名唯一性,具体如下:

mounted() {  this.name = window.sessionStorage.getItem('username')  this.user_pic = window.sessionStorage.getItem('user_pic')  this.user_id = window.sessionStorage.getItem('user_id')  this.avatarForm = {    name: this.name, // 用户名    user_id: this.user_id // 用户ID  }  this.getUserAvata()}

点击用户头像上传图片:

怎么利用nodeJS+vue图片上传实现更新头像

2、node后端服务

需要用到的依赖:

"dependencies": {  "express": "^4.16.2",  "cors": "^2.8.5",  "formidable": "^1.1.1"}

具体代码如下:

var express = require('express');var app = express();//引入数据库模块存储用户当前的头像地址const db = require('../db/index');// 设置运行跨域const cors = require('cors')app.use(cors())// 处理图片文件中间件var formidable = require("formidable");fs = require("fs");// 暴露静态资源app.use('/public', express.static('public'));// 上传图片服务app.post('/upload', function (req, res) {    var info = {};    // 初始化处理文件对象    var form = new formidable.IncomingForm();    form.parse(req, function(error, fields, files) {        if(error) {            info.status = '1';            info.message = '上传头像失败';            res.send(info);        }        // fields 除了图片外的信息        // files 图片信息        console.log(fields);        console.log(files);        var user_id = parseInt(fields.user_id);        var fullFileName = fields.name + user_id + files.file.name;// 拼接图片名称:用户名+用户ID+图片名称        fs.writeFileSync(`public/${fullFileName}`, fs.readFileSync(files.file.path)); // 存储图片到public静态资源文件夹下        // 更新用户当前头像地址信息        const sql = 'update ev_users set user_pic = ? where id = ?';        db.query(sql, [fullFileName, user_id], function (err, results) {            // 执行 SQL 语句失败            if (err) {                info.status = '1';                info.message = '上传失败';                        return (info)            }            info.status = '0';            info.message = 'success';            info.class="lazy" data-srcurl = fullFileName;            res.send(info);        });    });});var server = app.listen(3007, function () {    var host = server.address().address;    var port = server.address().port;    console.log('Example app listening at http://localhost:%s', port);});

分析:通过express创建端口号为3007的服务。引入formidable中间件存储图片,存储后将图片路径返回给前端。并将用户头像路径信息存入用户表,和用户绑定,这样每次用户登录后就能得到当前用户的头像路径信息,从而渲染自己的头像。formidable解析后,得到用户上传的信息:fields除了图片外的信息,files图片信息。

上传后的效果:

怎么利用nodeJS+vue图片上传实现更新头像

到此,相信大家对“怎么利用nodeJS+vue图片上传实现更新头像”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么利用nodeJS+vue图片上传实现更新头像

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么利用nodeJS+vue图片上传实现更新头像

本篇内容主要讲解“怎么利用nodeJS+vue图片上传实现更新头像”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用nodeJS+vue图片上传实现更新头像”吧!思路:前端通过el-uplo
2023-06-30

js怎么利用FileReader实现图片转base64格式并上传预览头像

今天小编给大家分享一下js怎么利用FileReader实现图片转base64格式并上传预览头像的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一
2023-06-30

nodejs利用ajax实现网页无刷新上传图片实例代码

通常情况下上传图片是要通过提交form表单来实现的,但是这又不可避免的产生了网页转。利用ajax技术和FormData()对象可以有效的解决这个问题 废话不多说 直接上关键代码: html部分
2022-06-04

PHP中怎么利用Ajax实现无刷新上传图片

PHP中怎么利用Ajax实现无刷新上传图片,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。PHP Ajax客户端页面代码: index.html
2023-06-17

Vue vant-ui怎么使用van-uploader实现头像上传功能

本篇内容主要讲解“Vue vant-ui怎么使用van-uploader实现头像上传功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue vant-ui怎么使用van-uploader实现头
2023-06-30

怎么用Vue+NodeJS实现大文件上传

本文小编为大家详细介绍“怎么用Vue+NodeJS实现大文件上传”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Vue+NodeJS实现大文件上传”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。常见的文件上传
2023-06-30

怎么用php实现图片上传

这篇文章主要介绍了怎么用php实现图片上传的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用php实现图片上传文章都会有所收获,下面我们一起来看看吧。一、创建html页面首先,我们要创建一个html页面,这个
2023-07-05

vue+axios怎么实现图片上传识别人脸

本篇内容主要讲解“vue+axios怎么实现图片上传识别人脸”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue+axios怎么实现图片上传识别人脸”吧!先看最终效果:这里采用的是vant的文件
2023-06-25

怎么使用PHP实现用户头像上传功能

这篇文章将为大家详细讲解有关怎么使用PHP实现用户头像上传功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。补充:什么是switch语句,以及它适用于哪些地方?简单的说switch语句也是属于判断语句,i
2023-06-15

怎么使用vue实现微信端图片压缩上传

这篇文章主要介绍“怎么使用vue实现微信端图片压缩上传”,在日常操作中,相信很多人在怎么使用vue实现微信端图片压缩上传问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用vue实现微信端图片压缩上传”的疑
2023-07-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录