小程序获取用户openId,session_key;node后端

流程:
1.前端用wx.login()方法拿到code,然后把code给后端;
2.后端拿code,appid,secret去请求微信后台接口;
3.接口会返回用户数据,包括openid和session_key,拿到openId再返回给前端

小程序端:

// 登录
    wx.login({
      success: res => {
        console.log("login success res",res)
        // 发送 res.code 到后台换取 openId, sessionKey, unionId

				wx.request({
					url: 'http://localhost:8086/getUserInfo',
					data: { code: res.code },
					method: 'POST', // OPTIONS, GET, HEAD, POST, PUT, DELETE, TRACE, CONNECT
					header: {
						'content-type': 'application/x-www-form-urlencoded'
					},// 设置请求的 header
					success: function (res) {
						console.log('获取用户unionId', res);
					},
					fail: function () {
						console.log("index.js wx.request CheckCallUser fail");
					},
					complete: function () {

						// complete
					}
				})

      }
    })

node.js端

//  获取openId
app.post("/getUserInfo", async (req, res) => {

    console.log('从前台获取来的req.body',req.body);

    if(req.body.code) {
      let options = {
          method: 'POST',
          url: 'https://api.weixin.qq.com/sns/jscode2session?',
          formData: {
              appid: "wx7xxxxxxx0",		//appid
              secret: "710fxxxxxxx45b1a",		//密钥,在小程序后台获取
              js_code: req.body.code,		//用户code
              grant_type: 'authorization_code'
          }
      };
      request(options, (error, response, body) => {
        if(error) { //请求异常时,返回错误信息
            res.json({
                "status": "error",
            })
        } else {
          let _data = JSON.parse(body);
          res.json(_data);
          console.log('返回的用户id:',_data);
        }
      })
    }
})

成功
小程序获取用户openId,session_key;node后端_第1张图片

如果一直返回 40092 ,检查appid前后端是否一致,密钥是否错误
小程序获取用户openId,session_key;node后端_第2张图片

你可能感兴趣的:(小程序,Node.js)