1、H5页面是运行在微信浏览器的
2、需要与公众号关联(即需要openid)
3、判断需求是否需要弹窗告知用户授权操作
4、获取到的openid做本地存储,判断没有openid进行获取openid操作
5、这边的操作是不需要弹出授权框,且code不能重复使用,所以做了关注二维码弹窗且不能关闭弹唱操作
// 强制关注公众号,获取openid getCode = function () { if (sessionStorage.getItem("openid")&&sessionStorage.getItem("openid")!="undefined") { return false; } var code = getUrlParam(‘code‘) // 截取路径中的code,如果没有就去微信授权,如果已经获取到了就直接传code给后台获取openId var local = window.location.href; var APPID = ‘xxx‘; if (code == null || code === ‘‘) { window.location.href = ‘https://open.weixin.qq.com/connect/oauth2/authorize?appid=‘ + APPID + ‘&redirect_uri=‘ + encodeURIComponent(local) + ‘&response_type=code&scope=snsapi_base&state=#wechat_redirect‘ } else { getOpenId(code) //把code传给后台获取用户信息 } } getOpenId = function (code) { $.ajax({ type: ‘POST‘, dataType: ‘json‘, url: ‘xxx‘, data: { code: code }, success: function (res) { if (res.status == -1) { // 提示没有关注公众号 没有关注公众号跳转到关注公众号页面 console.log(‘您还未关注公众号喔‘); //二维码弹窗 $(‘.openPopup‘).click(); return; } else { // 本地存储这个openid,并刷新页面 sessionStorage.setItem("openid", res.data.openid); location.reload(); } } }); }
原文地址:https://www.cnblogs.com/congfeicong/p/11125575.html
时间: 2024-11-07 19:22:05