微信小程序Android和ios授权,uni-app之APP和小程序微信授权方法

uni-app 介绍

uni-app 是一个使用 Vue.js 开发跨平台应用的前端框架。

适用平台:Android、iOS、微信小程序。实现了一套代码,同时发布到Android、iOS、微信小程序。

APP微信授权

检测服务商

检测手机上是否安装微信、QQ、新浪微博等。

uni.getProvider({

service: 'oauth',

success: function (res) {

console.log(res.provider);

}

});

66f45cd4579987ca3a383fb10d5e0ed8.png

授权登录

获取openid,(unionid)等

uni.login({

provider: 'weixin',

success: function (loginRes) {

console.log(JSON.stringify(loginRes));

}

});

获取用户信息

uni.getUserInfo({

provider: 'weixin',

success: function(infoRes) {

console.log('-------获取微信用户所有-----')

console.log(JSON.stringify(infoRes.userInfo));

}

});

示例代码

APP微信授权登录

appLogin: function() {

uni.getProvider({

service: 'oauth',

success: function(res) {

console.log(res.provider);

//支持微信、qq和微博等

if (~res.provider.indexOf('weixin')) {

uni.login({

provider: 'weixin',

success: function(loginRes) {

console.log('-------获取openid(unionid)-----');

console.log(JSON.stringify(loginRes));

// 获取用户信息

uni.getUserInfo({

provider: 'weixin',

success: function(infoRes) {

console.log('-------获取微信用户所有-----');

console.log(JSON.stringify(infoRes.userInfo));

}

});

}

});

}

}

});

},

小程序微信授权

获取用户基本信息

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

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

示例代码:

微信授权获取用户信息

wxGetUserInfo:function(res){

if (!res.detail.iv) {

uni.showToast({

title: "您取消了授权,登录失败",

icon: "none"

});

return false;

}

console.log('-------用户授权,并获取用户基本信息和加密数据------')

console.log(res.detail);

},

微信登录

(1)页面uni.login获取code

(3)示例代码

微信登录

wxLogin: function() {

uni.login({

provider: 'weixin',

success: function(loginRes) {

console.log('-------获取code-------')

console.log(loginRes.code);

wx.request({

url: 'https://xxxxx'+loginRes.code,

success: function(info) {

console.log('-------获取sessionKey、openid(unionid)-------')

console.log(info);

},

fail: function(e) {

console.log(e)

}

})

}

});

}

微信登录状态监测

微信登录检测

checkLogin: function() {

wx.checkSession({

success() {

console.log('ok');

// session_key 未过期,并且在本生命周期一直有效

},

fail() {

// session_key 已经失效,需要重新执行登录流程

//wx.login() // 重新登录

console.log('expire');

}

})

},

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值