nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

   2023-02-09 学习力0
核心提示:前言:这两天把小程序的页面和小程序支付给解决掉了,当然啦微信支付也是前后端一块写的,以及支付成功回调函数等,当然了这篇记录的不是微信支付,微信支付我会在一个完整的时间整理出来。这篇主要就是给大家讲一下文件上传删除,这一片呢就以图片上传删除为

前言:

这两天把小程序的页面和小程序支付给解决掉了,当然啦微信支付也是前后端一块写的,以及支付成功回调函数等,当然了这篇记录的不是微信支付,微信支付我会在一个完整的时间整理出来。这篇主要就是给大家讲一下文件上传删除,这一片呢就以图片上传删除为例。

好多人有一个误区,特别是在网上搜了一大堆方法之后更是一头雾水,今天就给大家介绍一下我使用的最简单的方法。

技术点:

  • vue+elementUi 使用el-upload上传图片
  • nodejs + koa. 使用fs+koa-multer实现将图片保存在服务器以及删除图片

一.vue+element使用el-upload上传图片

老样子,话不多说先上图:

nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

 

 

在上代码:

 

 

 1 <el-upload
 2           action="/upload/friedChickensImg"
 3           list-type="picture-card"
 4           :limit="1"
 5           :on-preview="preview"
 6           :on-success="afterSuccessUpload"
 7           :before-remove="handleRemove"
 8         >
 9           <i class="el-icon-plus"></i>
10         </el-upload>
11         <el-dialog :visible.sync="dialogVisible">
12           <img width="100%" :src="dialogImageUrl" alt />
13         </el-dialog>

 

 

 

 

这里主要有几个方法就是删除呀预览呀等等大家去官网一看便知! 

其实前端处理很简单只需要这几行代码就ok,我们具体来看后端代码!

 

二.nodejs + koa. 使用fs+koa-multer实现将图片保存在服务器以及删除图片

上传成功:

nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

 

nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

 

 

删除成功:

nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

 

 nodejs+koa+vue实现上传文件(图片)到服务器以及删除图片

 

 

先看图片我们跟能直观的感受到,接下来

上代码:

首先呢就是下载koa-multer,大家自行百度 npm i koa-multer --saver  , 接着配置参数

 1 const multer = require('koa-multer');//加载koa-multer模块
 2 
 3 //文件上传
 4 var storage = multer.diskStorage({
 5   //文件保存路径
 6   destination: function (req, file, cb) {
 7     cb(null, 'C:/friedChickens/friedChickensImg')
 8   },
 9   //修改文件名称
10   filename: function (req, file, cb) {
11     var fileFormat = (file.originalname).split(".");
12     cb(null,Date.now() + "." + fileFormat[fileFormat.length - 1]);
13   }
14 })
15 //加载配置
16 var upload = multer({ storage: storage });

直接复制代码大家不要问那么多,不懂得可以留言,傻瓜式操作!

然后就是给前端提供一个接口简简单单三行代码:

 1 const multer = require('koa-multer');//加载koa-multer模块
 2 
 3 //文件上传
 4 var storage = multer.diskStorage({
 5   //文件保存路径
 6   destination: function (req, file, cb) {
 7     cb(null, '/friedChickensImg')
 8   },
 9   //修改文件名称
10   filename: function (req, file, cb) {
11     var fileFormat = (file.originalname).split(".");
12     cb(null,Date.now() + "." + fileFormat[fileFormat.length - 1]);
13   }
14 })
15 //加载配置
16 var upload = multer({ storage: storage });
17 /* 上传图片 */
18 router.post('/friedChickensImg', upload.single('file'), async (ctx, next) => {
19   ctx.body = {
20     filename: ctx.req.file.filename,//返回文件名
21     path:'/friedChickensImg'
22   }
23 })

 

 这里大家需要注意一点的就是,图片保存的路径可以任意写!

 

到此呢,你调用此接口就可以看到你的服务器成功的上传了一张照片,????????????

然后就是

删除图片:

删除图片就直接给大家贴出来完整的代码,不做过多的赘述!

 1     deleteFolderRecursive(url, name) {
 2         var files = [];
 3 
 4         if (fs.existsSync(url)) {    //判断给定的路径是否存在
 5 
 6             files = fs.readdirSync(url);    //返回文件和子目录的数组
 7 
 8             files.forEach(function (file, index) {
 9 
10                 var curPath = path.join(url, file);
11 
12                 if (fs.statSync(curPath).isDirectory()) { //同步读取文件夹文件,如果是文件夹,则函数回调
13                     deleteFile(curPath, name);
14                 } else {
15 
16                     if (file.indexOf(name) > -1) {    //是指定文件,则删除
17                         fs.unlinkSync(curPath);
18                         console.log("删除文件:" + curPath);
19                     }
20                 }
21             });
22         } else {
23             console.log("给定的路径不存在!");
24         }
25     }

两个参数,第一个是存放文件的路径,第二个参数就是文件名称!

代码里有少量的注释大家自行观看!

至此呢删除文件就大功告成。????????????

结束语:

我的随笔呢大都以代码为主,并且是测试可以正常使用,大家只要拿到项目里就可以直接使用,是不是很傻瓜?如果大家有不懂的可以留言或者是加我wx:18237266724,就到这里吧洗洗睡觉!!!

 
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • 打造自己的 nodejs 静态文件服务器(帖子内容,
    用NodeJS打造你的静态文件服务器在《The Node Beginner Book》的中文版(http://nodebeginner.org/index-zh-cn.html)发布之后,获得国内的好评。也有同学觉得这本书略薄,没有包含进阶式的例子。@otakustay同学说:“确实,我的想法是在这之上补一个简单的MV
    02-10
  • NodeJS无所不能:细数10个令人惊讶的NodeJS开源
    在几年的时间里,NodeJS逐渐发展成一个成熟的开发平台,吸引了许多开发者。有许多大型高流量网站都采用NodeJS进行开发,像PayPal,此外,开发人员还可以使用它来开发一些快速移动Web框架。  除了Web应用外,NodeJS也被应用在许多方面,本文盘点了NodeJS在其
    02-10
  • Linux环境下的Nodejs linux安装基本环境
    最近在学习Node.js,在window下总是觉得不那么爽快。最简单而且环保的方法是在虚拟机中安装一个Linux。 { 1.Linux:家中的Linux为Centos。 2.VirtuallyBox: 开启2块网卡。第一个选Host-Only目的是为了让虚拟机通上网。第二块选Bridge Adapter,这是为了
    02-09
  • nodejs package.json说明
    {"name": "test", //项目名称(必须),由小写英文字母、数字和下划线,不能含空格"version": "1.0.0", //项目版本(必须)"description": "This is for study gulp project !", //项目描述(必须)"homepage": "", //项目主页url " key
    02-09
  • 017 nodejs取参四种方法req.body,req.params,re
    摘要: nodejs取参四种方法req.body,req.params,req.param,req.body 获取请求很中的参数是每个web后台处理的必经之路,nodejs提供了四种方法来实现。获取请求很中的参数是每个web后台处理的必经之路,nodejs的 express框架 提供了四种方法来实现。req.bodyre
    02-09
  • Docker windows下安装并搭建Nodejs的webapp
    Docker windows下安装并搭建Nodejs的webapp
    一、关于Docker什么是Docker?Docker 采用go语言编写,是一个开源的应用容器引擎。让开发者可以快速打包他们的应用以及依赖包到一个封装的可移植的容器Image中,然后发布到任何流行的机器( Linux ,windows,Mac等)上,也可以实现虚拟化。容器是使用完全
    02-09
  • Nodejs+Express+Mysql实现简单用户管理增删改查
    Nodejs+Express+Mysql实现简单用户管理增删改查
     源码地址  https://github.com/king-y/NodeJs/tree/master/user目录结构  mysql.jsvar mysql = require('mysql');var pool = mysql.createPool({host : '127.0.0.1',user : 'root',password : '',database : 's79'});exports.que
    02-09
  • nodejs查看本机hosts文件域名对应ip
    const dns = require('dns')dns.lookup('domainName', function(err, result) {console.log(result)}) related:https://***.com/questions/36689536/how-to-resolve-hostname-to-an-ip-address-in-node-js
    02-09
  • nodejs process.memoryUsage() rss等参数啥含义
    nodejs process.memoryUsage() rss等参数啥含义
    1 前言使用process.memoryUsage() ,然后可以得到一个对象如下:{ rss: 4935680,heapTotal: 1826816,heapUsed: 650472,external: 49879}  然而不知道rss是什么缩写,不知道其含义,网上找了一圈,多数都没说到点上,我这边就补充一下,也作为记录使用。2 
    02-09
  • nodejs工程拷贝后运行报module找不到问题
    工程文件夹通过复制黏贴到另外一个地方,运行后报错 “can`t find module 某某某”,查看原因:输入node 进入控制台,输入console.log(module.paths)查看当前nodejs查找module的路径,如果没有工程里的node_modules,通过module.paths.push加入,检查是否有效
    02-09
点击排行