微信小程序 同步请求授权的详解

发布时间 - 2026-01-11 02:39:14    点击率:

微信小程序 同步请求授权的详解

需求分析:

1.在小程序首次打开的时候,我需要同时请求获取多个权限,由用户逐一授权。

([‘scope.userInfo',‘scope.userLocation',‘scope.address',‘scope.record',‘scope.writePhotosAlbum']) 

问题分析:

1. wx.authorize接口同时调用,请求多个权限,由于异步原因,将授权请求一并发出,显然不符合要求。

2. promise能很好的解决问题,试着尝试了一下,下面代码分为两个文件。

// scope.js
import es6 from '../helpers/es6-promise'

// 获取用户授权
function getScope(scopeName) {
 return new es6.Promise(function (resolve, reject) {
  // 查询授权
  wx.getSetting({
   success(res) {
    if (!res.authSetting[scopeName]) {
     // 发起授权
     wx.authorize({
      scope: scopeName,
      success() {
       resolve(0)
      }, fail() {
       resolve(1)
      }
     })
    }
   }
  })
 })
}

module.exports = { getScope: getScope }

// index.js
import scope from "../../service/scope"
Page({
onShow() {
  let list = ["scope.userInfo", "scope.userLocation", "scope.address", "scope.record"];
  // 记录请求结果
  let num = 0;
  // 问题1:怎么改成循环方式?
  scope.getScope(list[0]).then(function (res) {
   num += res;
   scope.getScope(list[1]).then(function (res) {
    num += res;
    scope.getScope(list[2]).then(function (res) {
     num += res;
     scope.getScope(list[3]).then(function (res) {
      num += res;
      // 调起设置界面
      if (num) {
       wx.openSetting({
        success(res) {
         // 允许获取用户信息
         if (res.authSetting["scope.userInfo"])
          userService.login()
        }
       })
      } else {
       userService.login()
      }
     })
    })
   })
  })
})

分析求解:

1.代码中问题1写法过于笨,但是尝试通过循环方式调用写法,又不知道如何处理回调问题。

2.wx.authorize接口,success参数官方给出的解释是(接口调用成功的回调函数),其实不然,实际上是接口调用成功,并且获取到了scope指定的权限

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# 微信小程序  # 同步请求授权  # 小程序  # 微信小程序设置http请求的步骤详解  # 微信小程序之GET请求的实例详解  # 微信小程序 网络请求(GET请求)详解  # 微信小程序 POST请求的实例详解  # 微信小程序 网络请求(post请求  # get请求)  # 微信小程序 http请求封装详解及实例代码  # 微信小程序HTTP接口请求封装代码实例  # 微信小程序网络请求封装示例  # 微信小程序请求前置的方法详解  # 多个  # 回调  # 很好  # 首次  # 如有  # 希望能  # 解决问题  # 不符合  # 又不  # 其实不然  # 谢谢大家  # 试着  # 如何处理  # 疑问请  # wx  # writePhotosAlbum  # record  # authorize  # promise  # js 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel Blade组件怎么用_Laravel可复用视图组件的创建与使用  HTML透明颜色代码怎么让下拉菜单透明_下拉菜单透明背景指南【技巧】  如何在IIS7上新建站点并设置安全权限?  Win11摄像头无法使用怎么办_Win11相机隐私权限开启教程【详解】  奇安信“盘古石”团队突破 iOS 26.1 提权  网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?  Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程  如何在企业微信快速生成手机电脑官网?  阿里云高弹*务器配置方案|支持分布式架构与多节点部署  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  如何登录建站主机?访问步骤全解析  网站制作壁纸教程视频,电脑壁纸网站?  Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】  laravel怎么用DB facade执行原生SQL查询_laravel DB facade原生SQL执行方法  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  如何在万网ECS上快速搭建专属网站?  详解Android中Activity的四大启动模式实验简述  电商网站制作价格怎么算,网上拍卖流程以及规则?  如何用PHP工具快速搭建高效网站?  Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践  php打包exe后无法访问网络共享_共享权限设置方法【教程】  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?  网站制作大概多少钱一个,做一个平台网站大概多少钱?  深圳网站制作平台,深圳市做网站好的公司有哪些?  Laravel如何使用模型观察者?(Observer代码示例)  Laravel如何为API生成Swagger或OpenAPI文档  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  实现点击下箭头变上箭头来回切换的两种方法【推荐】  ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】  如何用IIS7快速搭建并优化网站站点?  在Oracle关闭情况下如何修改spfile的参数  Firefox Developer Edition开发者版本入口  邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?  Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】  如何快速生成专业多端适配建站电话?  标题:Vue + Vuex 项目中正确使用 JWT 进行身份认证的实践指南  Laravel中间件起什么作用_Laravel Middleware请求生命周期与自定义详解  Swift开发中switch语句值绑定模式  音乐网站服务器如何优化API响应速度?  如何挑选最适合建站的高性能VPS主机?  如何快速上传自定义模板至建站之星?  微信小程序 require机制详解及实例代码  Laravel怎么写单元测试_PHPUnit在Laravel项目中的基础测试入门  JS弹性运动实现方法分析  Laravel怎么使用Collection集合方法_Laravel数组操作高级函数pluck与map【手册】  如何确认建站备案号应放置的具体位置?  Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】