h5公众号一进来就调取授权登录

第一种是直接进来调取授权登录:

  1. 判断是否存在token
  2. 判断是否存在state和code
  3. 判断后端返回来的tokenId
  4. 登录失效重新调取授权

第一个判断是否有token:

  • 如果存在token,就直接一进来就调用列表数据
  • 不存在token的话,就去判断是否存在code和state

第二是判断是否存在code和state:

  • 如果存在code和state的话,就直接调取授权登录
  • 如果不存在code和state,就重新调取授权登录

第三步是直接授权登录:

  • 判断后端返回来的字段是否存在
  1. 存在的话,就直接调取列表数据
  2. 不存在的话,就去调取登录注册页面 

第四步是登录失效,报401

  1. 在request.js文件写入
  • 
    import { Toast, Dialog } from 'vant'
    import router from '@/router' 
    Dialog.alert({
              message: res.msg
            }).then(() => {
              router.push({ name: 'Home', query: { state_code : 'status' } })
            })
    2.在主页中,获取路由传参
  • const status = this.$route.query.status_code
    if(status){
        //调取授权
    }else {
        //走前面三部
    }

截取授权跳转获取的state,id还有code ,在public文件下新建一个html文件,代码如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script>
        // let href = window.location.href;
        // let auth_code = window.location.auth_code;
        let code = getQueryVariable('code')
        let state = getQueryVariable('state')
        let id = getQueryVariable('id')
        function getQueryVariable(variable) {
            var query = window.location.search.substring(1);
            var vars = query.split("&");
            for (var i = 0; i < vars.length; i++) {
                var pair = vars[i].split("=");
                if (pair[0] == variable) { return pair[1]; }
            }
            return (false);
        }
        let url = `http:...?code=${code}&state=${state}&id=${id}`//http是后端给的
        window.location.href = url
        console.log(url,'url')
        console.log(code)
        console.log(id)
        console.log(state)
    </script>
</head>

<body>
</body>

</html>

调取授权代码:

getLogin () {
      var ua = navigator.userAgent.toLowerCase() // 判断是否是微信浏览器
      var isWeixin = ua.indexOf('micromessenger') !== -1 // 判断是否
      if (!isWeixin) {
        Toast('请在微信浏览器中打开')
        return false
      }
      const token = this.$store.state.token
      if (!token) {
        console.log('没有token登录')
        const appid = ''//后端提供
        const url = '' //后端提供跳转的地址
        window.location.href = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${url}&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect`
      }
    },

授权登录代码:

// 进来有传参就授权登录
    getWxLogin (code, state) {
      const data = {
        code,
        state
      }
      this.$toast.loading({
        duration: 0,
        forbidClick: true,
        mask: true,
        message: '加载中...'
      })
      wxLogin(data).then(res => {
        this.$toast.clear()
        const data = res.data
        this.openid = data.openid
        this.apitoken = data.apitoken
        if (data.openid) {
          this.$store.commit('SET_OPENID', data.openid)
        }
        // 新用户弹窗绑定手机号
        if (!data.apitoken) {
          this.$refs.login.show = true
        } else {
          // this.$store.commit('c', data.apitoken)
          localStorage.setItem('token', data.apitoken)
          this.getList()
          this.getuserInfo()
        }
      })
    }

官方授权接口:

// 微信授权
export function wxLogin (params) {
  return request({
    url: 'http:..../login/wechat',
    method: 'get',
    params
  })
}

第二种页面点击某个按钮授权:

  1. 判断是否含有token
  2. 判断是否含有state和code还有id
  • 如果存在token:直接调取页面数据
  • 不存在token的话,就判断是否含有state和code还有id
  • 如果存在state和code还有id,就直接调取授权登录
  • 不存在state和code等,就调取授权
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值