微信H5获取用户基本信息

一、前端根据appID获取code(code通过链接重定向返回,从重定向链接中去截取)

      // 获取微信用户code
      getCode() {
        let appid = '可申请测试的appID';
        let url = `https://open.weixin.qq.com/connect/oauth2/authorize?appid=${appid}&redirect_uri=${encodeURIComponent(location.href)}&response_type=code&scope=snsapi_base&state=STATE&connect_redirect=1#wechat_redirect`;
        this.code = this.getUrlCode().code;
        //如果没有code 去获取code
        if (this.code == null) {
          window.location.href = url;
        }else{
          //获取到code后的逻辑
          console.log('code', this.code);
          // this.getOpenid(this.code)
        }
      },
      // 截取url中的code
      getUrlCode() {
        var url = location.search;
        var theRequest = new Object();
        if (url.indexOf("?") !== -1) {
          var str = url.substr(1)
          var strs = str.split("&");
          for (var i = 0; i < strs.length; i++) {
            theRequest[strs[i].split("=")[0]] = (strs[i].split("=")[1])
          }
        }
        return theRequest;
      },

微信公众平台测试帐号申请地址:https://mp.weixin.qq.com/debug/cgi-bin/sandbox?t=sandbox/login

二、后台根据appID、密钥、code获取openId

请求链接:https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code

参考文档:微信开放文档 (qq.com)

注意:这里的接口也会返回 access_token 但不是我们需要的 要用下面接口获取通用的
           code只能使用一次 每次都会变化 openId针对公众号和用户这两个维度 是唯一的

 三、后台根据appID和密钥获取access_token

请求链接:https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=APPID&secret=APPSECRET

参考文档:微信开放文档 (qq.com)

 四、后台根据openId和access_token获取用户基本信息

请求链接:https://api.weixin.qq.com/cgi-bin/user/info?access_token=ACCESS_TOKEN&openid=OPENID&lang=zh_CN

参考文档:微信开放文档 (qq.com)

注意:以上流程后面三步在前端也可以走,但是出于安全考虑,微信提议还是放到后端比较好,因为涉及到公众号密钥,暴露在前端不太好。当然,第一步获取code也可以直接在后端进行,只要在微信环境中进入后端接口,后端可以采用同样的方式获取code后并重定向回到前端页面。

参考:

微信h5静默、非静默授权获取用户openId的方法和步骤_飞歌Fly的博客-CSDN博客_微信静默授权

h5微信登录授权获取code(测试账号)_江湖浪子女见愁的博客-CSDN博客_h5微信登录

微信H5页面判断用户是否已关注公众号,以及唤起关注公众号页面 - 简书 (jianshu.com)

五、查询当前用户是否关注公众号

https://api.weixin.qq.com/cgi-bin/user/info?access_token=${ACCESS_TOKEN}&openid=${OPENID}&lang=zh_CN

  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信H5网页授权是指在使用微信浏览器访问H5网页时通过微信授权登录,获取用户基本信息。这个过程分为三个步骤:引导用户授权、获取授权码、通过授权码获取用户信息。 首先,用户进入H5网页后,网页需要引导用户进行授权登录。网页可以通过调用微信JS-SDK中的微信授权接口,弹出微信授权登录的窗口。用户点击确认后,微信会生成一个授权码,并跳转回H5网页。 然后,网页需要使用授权码去微信服务器获取用户基本信息。网页可以通过HTTP请求,将授权码发送给微信服务器的接口,并附上AppID和AppSecret等参数。微信服务器验证授权码的有效性后,会返回用户基本信息,如openid、昵称、头像等。 最后,网页可以根据获取用户基本信息,进行相应的业务操作。比如显示用户的头像和昵称,或者根据openid等唯一标识,将用户与其它业务系统进行关联。 需要注意的是,进行微信H5网页授权需要先申请微信开放平台的开发者账号,并创建一个公众号或移动应用。通过在微信开放平台进行配置,获取AppID和AppSecret等必要的参数,用于网页授权的流程中。 总结起来,微信H5网页授权获取用户基本信息是通过使用微信的授权接口,引导用户进行授权登录,再通过授权码和微信服务器进行交互,最终获取用户基本信息。这个过程可以实现在H5网页上使用微信账号登录,并获取用户信息的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值