微信小程序上传头像的临时路径,持久化保存到服务器与数据库(nodejs后台开发)
创始人
2025-01-20 01:32:44
0

从微信小程序中返回的用户头像临时地址 http://tmp/H0GP7BW5HTQs846c0d9deef32d42f2203340efc4a5c3.jpeg 会失效,且只能一段时间内在微信访问,并且无法在公网访问用户头像临时地址avatarUrl。

所以需要将临时地址avatarUrl转成实际可用的地址保存到mysql数据库的wxusers表的avatarUrl列中,同时将新的图片路径保存到服务器的./public/upload目录下。

一开始我是这么写的:

微信小程序通过授权获取用户头像的wxml代码如下

      


对应的微信小程序TS代码如下

onChooseAvatar(e) { const { avatarUrl } = e.detail  this.setData({   avatarUrl, }) console.log("获取到用户输入的头像为"+ avatarUrl)      // 登录      var that = this;      wx.login({          success: function(res) {              //console.log(res.code)              // 发送 res.code 到后台换取 openId, sessionKey, unionId              if (res.code){                  wx.request({                      url: config.apiUrl + '/api/getOpenid',                      method: 'POST',                      data:{                          code:res.code,                      },                      success:function(response){                          console.log("成功获取到用户openid 下面开始获取头像:",response.data.openid)                          const openid = response.data.openid; wx.request({     url: config.apiUrl + '/api/avatarUrl',     method: 'POST',     data: {         openid,         avatarUrl,     },     success: function(res) {         console.log('submit success');         console.log("成功获取到用户头像存入数据库:",avatarUrl)     },     fail: function(res) {         console.log('submit fail');     } }) } }) }else{ console.log('wx.login()调用失败!'+res.errMsg); } } }) },


以nodejs为后台保存头像到mysql数据库的路由代码如下

const express = require('express'); const router = express.Router(); const sql = require('../sql'); const request = require("request"); //存入头像 router.post('/avatarUrl', (req, res) => {      const openid = req.body.openid;     const avatarUrl = req.body.avatarUrl;     const nickname = req.body.nickname;     const phoneNumber = req.body.phoneNumber;     const unionid = req.body.unionid;      // 创建MySQL查询     const sqlStr = 'SELECT * FROM wxusers WHERE openid = ?';     //res.json({openid: openid});     console.log(`查询到了`)     // 查询数据库     sql.query(sqlStr, [openid], function(err, result) {         if (err) {             console.error(err);             res.status(500).send('Database error');         } else {             // 检查是否有匹配的openId             if (result.length > 0) {                 const sqlStr = `UPDATE wxusers SET avatarUrl = '${avatarUrl}' WHERE openid = '${openid}'`;                 sql.query(sqlStr, (err, result) => {                     if (err) throw err;                     res.send('Data updated in the database.');                 });             } else {                 const sqlStr = `INSERT INTO wxusers (openid, avatarUrl, nickname, phoneNumber, unionid) VALUES ('${openid}','${avatarUrl}', 'default_user', 'default_user', 'default_user')`;                 sql.query(sqlStr, [openid, avatarUrl, nickname, phoneNumber, unionid], (err, result) => {                     if (err) throw err;                     res.send('Data inserted into the database.');                 });             }         }     });  });  module.exports = router;

接下来是第二次修改的,微信开发者工具在本地测试没有问题:

微信小程序通过授权获取用户头像的wxml代码如下:

    {theme}}" class="view-2">    


对应的微信小程序TS代码如下:

onChooseAvatar(e) {     const { avatarUrl } = e.detail     this.setData({     avatarUrl,     })     console.log("获取到用户头像avatarUrl:"+ avatarUrl)     // 下载头像图片     wx.downloadFile({     url: avatarUrl,     success(res) {     if (res.statusCode === 200) {     console.log('download success');     const tempFilePath = res.tempFilePath     console.log("获取到用户头像tempFilePath:"+ tempFilePath)     // 上传下载的图片     wx.uploadFile({     url: config.apiUrl + '/api/avatarUrl',     filePath: tempFilePath,     name: 'file',     formData: {     'openid': wx.getStorageSync('openid')     },     success(res) {     const data = JSON.parse(res.data)     console.log('upload success');     console.log("成功获取到用户头像存入数据库:", data.path);     },     fail(res) {     console.log('upload fail');     }     })     }     }     })     },


以nodejs为后台保存头像到mysql数据库的路由代码如下:

const express = require('express'); const router = express.Router(); const sql = require('../sql'); const multer = require('multer');  // 设置文件上传的目录 const storage = multer.diskStorage({     destination: function(req, file, cb) {         cb(null, './public/upload')     },     filename: function(req, file, cb) {         cb(null, Date.now() + '-' + file.originalname)     } })  const upload = multer({ storage: storage })  router.post('/avatarUrl', upload.single('file'), (req, res) => {     const openid = req.body.openid;     const avatarUrl = '/upload/' + req.file.filename;  // 创建MySQL查询     const sqlStr = 'SELECT * FROM wxusers WHERE openid = ?';  // 查询数据库     sql.query(sqlStr, [openid], function(err, result) {         if (err) {             console.error(err);             res.status(500).send('Database error');         } else { // 检查是否有匹配的openId             if (result.length > 0) {                 const sqlStr = `UPDATE wxusers SET avatarUrl = '${avatarUrl}' WHERE openid = '${openid}'`;                 sql.query(sqlStr, (err, result) => {                     if (err) throw err;                     res.json({ path: avatarUrl });                 });                 console.log("更新新路径", avatarUrl);             } else {                 const sqlStr = `INSERT INTO wxusers (openid, avatarUrl) VALUES ('${openid}','${avatarUrl}')`;                 sql.query(sqlStr, [openid, avatarUrl], (err, result) => {                     if (err) throw err;                     res.json({ path: avatarUrl });                 });                 console.log("插入新路径", avatarUrl);             }         }     }); });  module.exports = router;

本地运行后微信开发者显示下面的内容:

 然后将服务搬到服务器上运行之后,开始报错:

 目前解决办法我也已经找到了:点击阅读完美解决方案icon-default.png?t=N6B9http://t.csdn.cn/nI1pI

相关内容

热门资讯

为了进一步!微信闲来神器软件下... 为了进一步!微信闲来神器软件下载(辅助)确实是真的有辅助神器(有挂技巧)1、微信闲来神器软件下载有没...
现场直击!微信边锋辅助器(辅助... 现场直击!微信边锋辅助器(辅助)都是真的有辅助教程(有挂攻略)1、每一步都需要思考,不同水平的挑战会...
最新消息!微信超级3+1挂辅助... 最新消息!微信超级3+1挂辅助(辅助)竟然真的是有辅助软件(有挂辅助)1)微信超级3+1挂辅助免费钻...
昨日!789大菠萝有挂吗(辅助... 昨日!789大菠萝有挂吗(辅助)好像是有辅助工具(有挂神器)1、全新机制【789大菠萝有挂吗ai辅助...
黑科技代打!柳州八一字牌辅助(... 黑科技代打!柳州八一字牌辅助(辅助)一直确实有辅助攻略(今日头条)1、全新机制【柳州八一字牌辅助ai...
最终!福建天天开心辅助工具下载... 最终!福建天天开心辅助工具下载(辅助)切实真的有辅助攻略(有挂存在)1、福建天天开心辅助工具下载破解...
据报道!微信边锋辅助工具(辅助... 据报道!微信边锋辅助工具(辅助)一贯确实有辅助技巧(有挂技巧)微信边锋辅助工具辅助器是一种具有地方特...
第三方技巧!陕麻圈延安划水辅助... 您好,陕麻圈延安划水辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...
相较于以往!家乡大二辅助(辅助... 相较于以往!家乡大二辅助(辅助)本来真的是有辅助挂(有挂猫腻)1、家乡大二辅助透视辅助软件激活码多个...
近期!盛世透视辅助器(辅助)竟... 近期!盛世透视辅助器(辅助)竟然真的有辅助神器(有挂秘笈)1、超多福利:超高返利,海量正版游戏,盛世...