一、登录原理
1、调用wx.login获得 code
<view> <text>第1步:</text> <button type="primary" bindtap="wxlogin" size="mini">微信登录</button> </view>
// 第1步:微信登录, 得到code wxlogin() { wx.login({ success: (res) => { console.log("微信登录", res); this.setData({ code: res.code }) }, fail(err) { console.log(err); } }) },2、获取客户信息,wx.getUserInfo (要先授权), 获得 encryptedData,iv

文章插图
官方文档说明
(因为微信官方考虑到用户隐私,所以关闭了用户进入小程序时自动弹出获取用户信息的接口,只能通过button绑定getuserinfo事件来获取用户信息)
【小程序登录流程】<view> <text>第2步:</text> <button type="warn" open-type="getUserInfo" bindgetuserinfo="getUserInfo" size="mini"> 获取用户授权信息 </button></view>
// 第2步: 获取用户授权信息,得到encryptedData,iv getUserInfo(event) { console.log("用户授权信息", event.detail); let detail = event.detail; this.setData({ encryptedData: detail.encryptedData, iv: detail.iv }) },3、调用login接口,传入code,encryptedData,iv, 后台返回获得token
<view> <text>第3步:</text> <button type="primary" bindtap="login" size="mini">登录(我们自己的服务器)</button></view>
// 第3步:登录(我们自己的服务器) login() { let url = "/user/login"; let data = { code: this.data.code, encryptedData: this.data.encryptedData, iv: this.data.iv } App.$http.post(url, data, true).then(res => { console.log("登录", res); // 第4步,把后台返回的token存到本地缓存 try { wx.setStorageSync('token', res.user.token) } catch (e) { } }) },二、一键登录(三合一)
<button open-type="getUserInfo" bindgetuserinfo="login" type="default" size="mini" class='f14 ml-10'> 立即登入 </button>
// 一键登录 login(event) { // 1、获取 encryptedData, ivlet { encryptedData, iv } = event.detail; // 微信登录 wx.login({ success: (res) => { // 2、获取code let code = res.code; // 3、登录后台服务器 let url = "/user/login"; let data = https://www.isolves.com/it/cxkf/ydd/xcx/2019-08-01/{ encryptedData, iv, code } app.$http.post(url, data, true).then(res => { console.log("登录成功", res); this.setData({ token: res.user.token }) // 4、把token存到本地缓存 try { wx.setStorageSync('token', res.user.token) } catch (e) { } }) } }) },三、授权
wx.authorize()
onLoad: function (options) { // 查看用户是否授权 wx.getSetting({ success(res) { console.log("录音授权", res.authSetting['scope.record']) let record = res.authSetting['scope.record']; if (!record) { wx.authorize({ scope: 'scope.record', success() { // 用户已经同意小程序使用录音功能,后续调用 wx.startRecord 接口不会弹窗询问 wx.startRecord() } }) } } }) },
推荐阅读
-
央视军事|60年前的今天,“东风”起!中国人有了自己的导弹!
-
-
「娱乐密探」这两部著作有着很好的口碑,而赵今麦的长相也是,《流浪地球》和《少年派》
-
1660 2070 3080 6700是什么意思?
-
央视新闻客户端|日本下任首相怎么选?安倍接班人将接受啥考验?
-
-
解码|上线多天热度不减解码贺岁贵金属市场的大众收藏热
-
「掌上新闻」老爸发信息撩妹, 却不料发给了女儿, 女儿的回复让人笑半年!,开心短语:
-
养生十日谈|,非常令人遗憾,自尊被践踏!武汉14岁男生被母亲扇打后跳楼坠亡
-
-
「军迷圈视频」为何打越南耗时多年打伊拉克仅40天?专家答案点醒世人,同为美军
-
国际连连看|美疾控中心再警告:会播种新冠病毒致感染激增,疫情下暴乱持续
-
央视新闻客户端|山东青岛新增英国输入确诊病例1例和菲律宾输入无症状感染者1例病例详情
-
宅妹大吃|老是黄叶子?问题出在浇水上,切勿“勤浇水”,天堂鸟买回家
-
雅漾|痘痘和痘印怎么办 6款有效祛痘修复痘印的护肤品 明星都在用
-
影社会|伸冤54年,“受害者”帮忙寻找证据翻案,江西男教师被控强奸女学生入狱
-
贾静雯|《浪姐4》真闹矛盾?徐怀钰发动态疑呛声贾静雯,节目或五月开播
-
-
新华网|揭秘生肖牛年邮票——《辛丑年》特种邮票开机印刷
-