小程序开发(授权登陆)

授权登陆功能实现:

1.通过wx.getUserProfile接口获取用户信息,wx.login获取code

2.然后wx.request发送给后台,获取openid和session_key,保存用户信息

3.服务根据openid端随机生成一串唯一字符串为3rdSessionId

4.客户端使用wx.setstoragesync缓存3rdSessionId

5.用wx.getstoragesync获取3rdSessionId如果存在,就已经登陆,不存在就未登陆(检验登陆态)

wxml:

  <button bindtap="getUserInfos"></button>

js:

getUserInfos: function(e) {

    wx.getUserProfile({

      desc: '业务需要',

      success: res => {

//获取信息成功,调用

this.setCode( res.userInfo);

      }

    })

  },

setCode:function(a){

var that = this;

//code获取

wx.login({

success: function(res) {

        wx.request({

          method: 'GET',

          url: 'xxx.com',

 data: {

            code: res.code,

            userName: a.nickName,

            userImg: a.avatarUrl,

            gender: a.gender,

            city: a.city

          },

          header: {

            'content-type': 'application/json'

          },

success: function(res) {

//成功后

//缓存用户token

wx.setStorageSync('user', res.data)

          },

fail: function() {

         //失败   

          }

        })

      }

    })

  }

php解析code代码:

    $code = $_GET['code'];

    $appid = 'APPID';

    $AppSecret = 'APPSECRET';

    $url = "https://api.weixin.qq.com/sns/jscode2session?appid=".$appid."&secret=".$AppSecret."&js_code=".$code."&grant_type=authorization_code";

    $str = file_get_contents($url);

    $json = json_decode($str);

    $arr = get_object_vars($json);

    echo $openid = $arr['openid']; //这是openid

    echo $session_key = $arr['session_key']; //这是session_key

总结:

后台根据openid生成3rdSessionId发送到客户端,用作登陆态,最好是设置有时效性的。

本人菜鸟一枚,有什么错的地方希望大佬们多多包涵,小程序推荐,打扰了不好意思:

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiH5Y2D5aWz5oCn55qE5qKm,size_20,color_FFFFFF,t_70,g_se,x_16

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值