La ruta temporal para cargar avatares al subprograma WeChat y conservarlos en el servidor y la base de datos (desarrollo en segundo plano de nodejs)

La dirección temporal del avatar del usuario, http://tmp/H0GP7BW5HTQs846c0d9deef32d42f2203340efc4a5c3.jpeg, devuelta por el subprograma WeChat dejará de ser válida y solo se podrá acceder a ella dentro de un período de tiempo en WeChat, y la dirección temporal del avatar del usuario, avatarUrl, No se puede acceder a él en la red pública.

Por lo tanto, es necesario convertir la dirección temporal avatarUrl en una dirección realmente utilizable y guardarla en la columna avatarUrl de la tabla wxusers en la base de datos mysql, y al mismo tiempo guardar la nueva ruta de la imagen en el directorio ./public/upload. del servidor.

Al principio escribí esto:

El código wxml para que el subprograma WeChat obtenga el avatar del usuario mediante autorización es el siguiente

<view class="btnavatar">
    <button class="avatar-wrapper" open-type="chooseAvatar" bind:chooseavatar="onChooseAvatar"  value='{
   
   {avatarUrl}}'>
   <view>
    <image class="avatar" src="{
   
   {avatarUrl}}"></image>
   </view>
  </button>
</view>


El código TS del subprograma WeChat correspondiente es el siguiente

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);
}
}
})
},


El código de enrutamiento para guardar avatares en la base de datos MySQL usando nodejs como fondo es el siguiente

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;

La siguiente es la segunda modificación: la herramienta de desarrollo WeChat no tiene problemas en las pruebas locales:

El código wxml para que el subprograma WeChat obtenga el avatar del usuario mediante autorización es el siguiente:

    <view data-weui-theme="{
   
   {theme}}" class="view-2">
   <button class="avatar-wrapper" open-type="chooseAvatar" bind:chooseavatar="onChooseAvatar"  value='{
   
   {avatarUrl}}'>
   <view>
    <image class="avatar" src="{
   
   {avatarUrl}}"></image>
   </view>
  </button>


El código TS del subprograma WeChat correspondiente es el siguiente:

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');
    }
    })
    }
    }
    })
    },


El código de enrutamiento para guardar avatares en la base de datos MySQL usando nodejs como fondo es el siguiente:

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;

Después de ejecutarlo localmente, el desarrollador de WeChat muestra el siguiente contenido:

 Luego, después de mover el servicio al servidor y ejecutarlo, comenzaron a aparecer errores:

 También encontré la solución actual: haga clic para leer la solución perfecta icono-default.png?t=N6B9http://t.csdn.cn/nI1pI

Supongo que te gusta

Origin blog.csdn.net/qq_25501981/article/details/131493971
Recomendado
Clasificación