vue + 微信获取用户信息
本次项目作到一个点赞功能,即分享出去一个页面给微信好友,微信好友点开并点赞,须要将点赞用户的微信昵称,微信头像以及微信openid,微信unionid(这个须要关注公众号才会有该字段)传给后端,记录点赞人的相关信息vue
微信网页受权nginx
分享页面的实际连接:
⚠️ 当前页面的连接须要 encodeURIComponent( url ) 编码json
https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect // APPID: 公众号的appid // REDIRECT_URI:当前页面的连接,须要编码 // scope: snsapi_base / snsapi_userinfo // 其余值均不用改动
代码以下segmentfault
// created 周期 if(this.$route.query.from) { // 判断连接中是否有from参数,下面的studentId,activityId项目须要 let _nowUrl = window.location.href.split('?')[0] + `?resource=1&studentId=${this.$route.query.studentId}&activityId=${this.$route.query.activityId}` let _shareUrl = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appId}&redirect_uri=${encodeURIComponent(_nowUrl)}&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect` window.location.href = _shareUrl return }
// 处理微信用户信息 handleWechatMsg(code) { // 调取 获取微信用户信息的接口(后端参考微信官方文档进行封装) code--参数 api.getWechatInfo(code).then((res)=>{ if(res.data.code == 200) { // 返回的是json字符串 let _data = res.data.content let _personMsg = JSON.parse(_data) this.wechatMsg = _personMsg // 本地存储微信用户信息,防止页面被刷新,code失效 window.localStorage.setItem('wechatMesssage', _data) } else if (res.data.code == 400) { // 400-code失效,400是后端返回,具体看后端返回哪一个码 let msgs = window.localStorage.getItem('wechatMesssage') this.wechatMsg = JSON.parse(msgs) } else { this.$Message.message(res.data.message); } }) },
⚠️--------------------后端