广告
返回顶部
首页 > 资讯 > 精选 >怎么利用nodeJS+vue图片上传实现更新头像
  • 511
分享到

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

2023-06-30 10:06:43 511人浏览 安东尼
摘要

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

本篇内容主要讲解“怎么利用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" :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:文件上传成功时的钩子,这里接受图片路径成功后,拼接成正确的图片路径,并将路径赋值给src,具体如下:

handleAvatarSuccess(res, file) {  if (res.status === '1') return this.$message.error(res.message)  this.imageUrl = `http://localhost:3007/public/${res.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.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图片上传实现更新头像”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: 怎么利用nodeJS+vue图片上传实现更新头像

本文链接: https://www.lsjlt.com/news/328180.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 怎么利用nodeJS+vue图片上传实现更新头像
    本篇内容主要讲解“怎么利用nodeJS+vue图片上传实现更新头像”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用nodeJS+vue图片上传实现更新头像”吧!思路:前端通过el-uplo...
    99+
    2023-06-30
  • 利用nodeJS+vue图片上传实现更新头像的过程
    目录思路:1、前端准备2、node后端服务总结思路: 前端通过el-upload将图片传给后端服务,后端通过formidable中间件解析图片,生成图片到静态资源文件夹下(方便前端直...
    99+
    2022-11-13
  • 怎么用PHP+Ajax实现无刷新上传头像图片预览功能
    这篇文章主要讲解了“怎么用PHP+Ajax实现无刷新上传头像图片预览功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用PHP+Ajax实现无刷新上传头...
    99+
    2022-10-18
  • js怎么利用FileReader实现图片转base64格式并上传预览头像
    今天小编给大家分享一下js怎么利用FileReader实现图片转base64格式并上传预览头像的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一...
    99+
    2023-06-30
  • nodejs利用ajax实现网页无刷新上传图片实例代码
    通常情况下上传图片是要通过提交form表单来实现的,但是这又不可避免的产生了网页转。 利用ajax技术和FormData()对象可以有效的解决这个问题 废话不多说 直接上关键代码: html部分 &l...
    99+
    2022-06-04
    上传图片 实例 代码
  • js利用FileReader实现图片转base64格式并上传预览头像
    目录页面布局:思路分析:代码:修改用户头像,一般都会需要把图片转成base64格式,所以我们需要学会怎么利用FileReader转换 页面布局: <template> ...
    99+
    2022-11-13
  • PHP中怎么利用Ajax实现无刷新上传图片
    PHP中怎么利用Ajax实现无刷新上传图片,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。PHP Ajax客户端页面代码: index.html<html>&nb...
    99+
    2023-06-17
  • vue中怎么利用axios实现表单提交上传图片
    本篇文章为大家展示了vue中怎么利用axios实现表单提交上传图片,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。项目中用的element 的框架,然后在项目有一个添...
    99+
    2022-10-19
  • php中怎么利用ajax实现无刷新上传图片功能
    php中怎么利用ajax实现无刷新上传图片功能,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。<html> <bod...
    99+
    2022-10-19
  • Vue vant-ui怎么使用van-uploader实现头像上传功能
    本篇内容主要讲解“Vue vant-ui怎么使用van-uploader实现头像上传功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Vue vant-ui怎么使用van-u...
    99+
    2023-06-30
  • 怎么利用HTML5实现图片文件异步上传
    本篇内容介绍了“怎么利用HTML5实现图片文件异步上传”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2022-10-19
  • 怎么用Vue+NodeJS实现大文件上传
    本文小编为大家详细介绍“怎么用Vue+NodeJS实现大文件上传”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用Vue+NodeJS实现大文件上传”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。常见的文件上传...
    99+
    2023-06-30
  • 怎么用php实现图片上传
    这篇文章主要介绍了怎么用php实现图片上传的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么用php实现图片上传文章都会有所收获,下面我们一起来看看吧。一、创建html页面首先,我们要创建一个html页面,这个...
    99+
    2023-07-05
  • vue中如何使用axios post上传头像/图片并实时显示到页面
    这篇文章给大家分享的是有关vue中如何使用axios post上传头像/图片并实时显示到页面的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。html代码: <div...
    99+
    2022-10-19
  • Nodejs中怎么实现图片上传和压缩预览功能
    这篇文章给大家介绍Nodejs中怎么实现图片上传和压缩预览功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1、引入基本配置const Koa = req...
    99+
    2022-10-19
  • vue中怎么实现一个上传图片组件
    本篇文章给大家分享的是有关vue中怎么实现一个上传图片组件,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.首先得有一个[type=file]...
    99+
    2022-10-19
  • vue+axios怎么实现图片上传识别人脸
    本篇内容主要讲解“vue+axios怎么实现图片上传识别人脸”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue+axios怎么实现图片上传识别人脸”吧!先看最终效果:这里采用的是vant的文件...
    99+
    2023-06-25
  • 怎么使用PHP实现用户头像上传功能
    这篇文章将为大家详细讲解有关怎么使用PHP实现用户头像上传功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。补充:什么是switch语句,以及它适用于哪些地方?简单的说switch语句也是属于判断语句,i...
    99+
    2023-06-15
  • 怎么使用vue实现微信端图片压缩上传
    这篇文章主要介绍“怎么使用vue实现微信端图片压缩上传”,在日常操作中,相信很多人在怎么使用vue实现微信端图片压缩上传问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用vue实现微信端图片压缩上传”的疑...
    99+
    2023-07-04
  • 利用Spring Boot怎么样实现一个图片上传功能
    利用Spring Boot怎么样实现一个图片上传功能?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体内容如下package com.clou.inteface.domain....
    99+
    2023-05-31
    springboot spring boo
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作