nodeJs实现微信小程序的图片上传
今天我来介绍一下nodejs如何实现保存微信小程序传过来的图片及其返回
首先wx.uploadFile绝大部分时候是配合wx.chooseImage一起出现的,毕竟选择好了图片,再统一上传是实现用户图片上传的正常逻辑。
1 //添加图片 2 addImg: function() { 3 var that = this; 4 console.log(9 - that.data.checkImgLength) 5 if (9 - that.data.checkImgLength >= 1){ 6 wx.chooseImage({ 7 count: 9 - that.data.checkImgLength, // 默认9 8 sizeType: ['original', 'compressed'], // 可以指定是原图还是压缩图,默认二者都有 9 sourceType: ['album', 'camera'], // 可以指定来源是相册还是相机,默认二者都有 10 success: function (res) { 11 var tempFilePaths = res.tempFilePaths//这里拿到的是图片在微信客户端的临时路径!!! 12 let length = tempFilePaths.length; 13 let tempList = that.data.imgLists.concat(tempFilePaths);//JSON数据 14 that.setData({ 15 imgLists: tempList, 16 checkImgLength: that.data.checkImgLength + length//长度相加,这里是为了选择的图片不会超过9 17 }) 18 } 19 }) 20 } 21 },
这里要注意的是,第11行的路径是临时的,再刷新,这个路径就无用了,甚至这个时候复制这个路径到自己的浏览器里也没有用,这里要注意,正确的业务逻辑是传到自己的服务器,再保存到服务器,再由客户端通过服务器链接拿到图片。
下面是我的node服务器端的部分代码
1 var express = require("express"); 2 var formidable = require("formidable"); 3 var path = require("path") 4 var fs = require("fs") 5 var image = require("imageinfo") 6 const listenNumber = 5000; 7 8 var app = express(); 9 10 app.use(express.static('upload'))//这个很重要,必须要这个才能拿到图片链接,而不是进入路由,有兴趣的同学可以删掉试验一下 11 12 app.post("/upload", (req, res) => { 13 var form = new formidable.IncomingForm();//既处理表单,又处理文件上传 14 //设置文件上传文件夹/路径,__dirname是一个常量,为当前路径 15 let uploadDir = path.join(__dirname, "../upload/"); 16 form.uploadDir = uploadDir;//本地文件夹目录路径 17 18 form.parse(req, (err, fields, files) => { 19 let oldPath = files.cover.path;//这里的路径是图片的本地路径 20 console.log(files.cover.name)//图片传过来的名字 21 let newPath = path.join(path.dirname(oldPath), files.cover.name); 22 //这里我传回一个下载此图片的Url 23 var downUrl = "http://localhost:" + listenNumber + "/upload/" + files.cover.name;//这里是想传回图片的链接 24 fs.rename(oldPath, newPath, () => {//fs.rename重命名图片名称 25 res.json({ downUrl: downUrl }) 26 }) 27 }) 28 }) 29 30 app.listen(listenNumber)
部分重要逻辑大家可以按照自己的需求来做,这里需要引用的第三方包是express、formidable、path,大家可以在终端输入以下命令下载:
npm install express
npm install formidable
npm install path
第二十五行可以拿到图片在node服务器中的链接,大家可以通过小程序端的success回调函数拿到链接等数据,然后保存在data中,通过{{imgSrc}}进行渲染就能确定你的逻辑已经走通了。
希望我的教程能够帮到大家,加油!!!
# 博主说:哈喽大家,实在不好意思,这个文章实在是有一些久了,关于formidable或者其他库的使用之类的规则和详情都是变了的,小伙伴们可以看一下后面我一篇关于React富文本的文章,里面也有关于文件上传的node代码,链接在这儿: React+wangeditor+node富文本处理带图片上传