小程序授权登录获取用户信息及手机号

关于授权登录 ,微信接口调整:查看内容

为优化用户体验,使用 wx.getUserInfo 接口直接弹出授权框的开发方式将逐步不再支持。从2018年4月30日开始,小程序与小游戏的体验版、开发版调用 wx.getUserInfo 接口,将无法弹出授权询问框,默认调用失败。正式版暂不受影响。

一.开发者可使用以下方式获取或展示用户信息

1.使用 open-data 展示用户基本信息

注意:这个只能展示用户信息,不能保存到数据库

 2.使用 button 组件,并将 open-type 指定为 getUserInfo 类型,获取用户基本信息 

目前只知道获取手机号,用户信息,其他的邮箱,身份证 暂不支持

必须要这个按钮 才可以触发这个弹出框的事件

import Api from '../../dist/js/api';
let wxparse = require("../../wxParse/wxParse.js");
Page({
	data:{
        isLogin: false,
	},
	onLoad:function (argument) {
        var mythis = this;
        console.log(this.data.isLogin)
        // 获取用户信息
        wx.getSetting({
            success: res => {
                if (res.authSetting['scope.userInfo']) {
                    // 已经授权,可以直接调用 getUserInfo 获取头像昵称,不会弹框
                    mythis.setData({
                        isLogin: true
                    });
                    wx.getUserInfo({
                        success: res => {
                            console.log('获取用户信息', res)
                        }
                    })
                } else {
                    mythis.setData({
                        isLogin: false
                    });
                }
            }
        })
	},
    bindGetUserInfo: function (e) {
        console.log(e.detail.errMsg)
        //授权后的处理
        if (e.detail.errMsg =="getUserInfo:ok"){
            //用户信息
            console.log('用户信息',e.detail.userInfo)
            this.setData({
                isLogin: true
            });
        }
    }
})

 

3.手机号码

也是要按钮点击触发,授权,后端解析得到手机号码

import Api from '../../dist/js/api';
let wxparse = require("../../wxParse/wxParse.js");
Page({
    data: {
        isLogin: false,
        openidInfo:{}
    },
    onLoad: function (argument) {
        var _this = this;
        wx.login({
            success: function (res) {
                if (res.code) {
                    let params = {
                        code: res.code,
                        type:""
                    }
                    Api.getWxUserInfo(params).then(res => {
                        if (res.success == true) {
                            let userOpen = {
                                openId: res.data.openId,
                                userId: res.data.userId,
                                sessionKey: res.data.session_key
                            }
                            _this.setData({
                                openidInfo: userOpen
                            })
                        }
                    });
                } 
            }
        });
    },
    getPhoneNumber: function (e) {
        console.log(e.detail.errMsg)
        //授权后的处理
        if (e.detail.errMsg == "getPhoneNumber:ok") {
            //用户信息
            let params = {
                encrypdata:e.detail.encryptedData,
                ivdata: e.detail.iv,
                sessionkey:this.data.openidInfo.sessionKey
            }
            console.log('参数', params)
            //后端获取参数进行解密
            Api.getPhoneNumber(params).then(datas => {
                console.log('手机号码',res)
            })
            this.setData({
                isLogin: true
            });
        }
    }
})

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值