vue + 微信获取用户信息

vue + 微信获取用户信息

本次项目做到一个点赞功能,即分享出去一个页面给微信好友,微信好友点开并点赞,需要将点赞用户的微信昵称,微信头像以及微信openid,微信unionid(这个需要关注公众号才会有该字段)传给后端,记录点赞人的相关信息

微信网页授权

  1. 微信公众号网页授权配置,详见官网
  2. 关于网页授权的两种scope的区别说明 (详细见官网)
    -scope=snsapi_base 获取微信用户openid,获取后直接跳转业务页面,不需要用户操作
    -scope=snsapi_userinfo 获取微信用户详细信息(昵称,头像等),需要用户手动点击授权,当点击允许时,会跳转业务页面(类似于关闭弹窗),点击拒绝时会推出页面,授权如图:

在这里插入图片描述

  • ⚠️用户管理类接口中的“获取用户基本信息接口”,是在用户和公众号产生消息交互或关注后事件推送后,才能根据用户OpenID来获取用户基本信息。这个接口,包括其他微信接口,都是需要该用户(即openid)关注了公众号后,才能调用成功的。
  • 分享页面的实际链接:
    ⚠️ 当前页面的链接需要 encodeURIComponent( url ) 编码

  • 
    
    
    https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE
    // APPID: 公众号的appid
    // REDIRECT_URI:当前页面的链接,需要编码
    // scope: snsapi_base / snsapi_userinfo
    // 其他值均不用改动
    
  • 点击允许后跳转的链接是 REDIRECT_URI + code=CODE&state=STATE。
    ⚠️ 此处的code可以用来调取接口获取微信用户的相关信息
    ⚠️ 每次用户授权带上的code将不一样,code只能使用一次,5分钟未被使用自动过期。
    -官方说法code只能被使用一次,在H5页面中,如果有跳转的情况,再返回当前页面,微信会判断是否已经授权,如果授权过,则code返回的还是上一次的code,而你如果用code调取用户信息(code已失效)会报 invalid code, hints: [ req_id: GGJbIz4ce-oGYwya ],所以在第一次获取用户信息的时候就可以将该用户信息存储在本地
  • 需要获取用户信息,且二次分享的问题
    虽然当前页面没有问题,但是当前微信用户使用微信进行二次分享,则微信会分享当前页面的链接(不包含https://open.weixin.qq.com...),新用户点击则不会进行授权,但是微信的二次分享会在当前链接加上 &from= ,可以在vue created的生命周期里进行参数获取并判断,如果有from参数,则跳转 https://open.weixin.qq.com/co... 链接,让用户授权
    ⚠️ 二次分享样式显示问题可以查看我的另一篇文章 vue + 微信二次分享/自定义分享

  • 代码如下

    
    
    
    // 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);
          }
    
        })
      },
    
    • 如果需要获取微信unionid,则需要引导用户关注公众号,可以在返回的用户信息中判断是否含有unionid,如果没有,可以展示微信公众号的二维码,供用户识别关注

    ⚠️--------------------

    1. 当前页面的域名,需要在公众号后台配置添加(详见官网)
    2. 如果页面存在#,可能会出问题,可以使用nginx进行配置

    来源:https://segmentfault.com/a/1190000018588151

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue3 TS 微信小程序智慧医疗项目是一个基于Vue 3和TypeScript开发的微信小程序项目,旨在应用智慧医疗技术提供便捷、高效的医疗服务。 该项目通过Vue 3作为前端框架,结合TypeScript进行开发,具有以下特点: 1. 使用Vue 3:Vue 3是一种现代的JavaScript框架,具有响应式组件系统和虚拟DOM等特性,可以提高开发效率并提供更好的用户体验。 2. 使用TypeScript:TypeScript是一种强类型的JavaScript扩展语言,可以帮助开发者在编码阶段发现潜在的错误并提供更好的代码提示,提高代码的可读性和可维护性。 3. 微信小程序开发:该项目是基于微信小程序平台开发的,可以直接在微信中使用,支持多平台,包括iOS和Android等。 4. 智慧医疗功能:项目主要提供智慧医疗相关的功能,如在线挂号、医生预约、健康档案管理等。用户可以通过小程序轻松预约就诊,查询医生资料和挂号信息,同时管理个人的健康档案。 5. 数据管理与交互:项目采用Vue 3的数据管理工具Vuex来管理组件间的状态和数据流动,通过与后端接口的交互获取和更新数据,确保数据的准确性和一致性。 总而言之,Vue3 TS 微信小程序智慧医疗项目是一个利用Vue 3和TypeScript开发的微信小程序,旨在为用户提供便捷、高效的智慧医疗服务,通过在线挂号、医生预约和健康档案管理等功能,提升用户的医疗体验和健康管理能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值