当前位置: 首页 > news >正文

uniapp解决上架华为应用市场审核要求-监听权限的申请

支持android平台全局监听权限的申请。当申请权限时,会在页面顶部显示申请权限的目的。主要解决上架华为应用市场审核要求:APP在调用终端权限时,应同步告知用户申请该权限的目的。

因为如果不提示,你上架应用市场会被打打回来

Tips

插件需要云打包生成自定义基座才会生效。
如果在其他插件中跳转到单独的activity并在此activity中申请权限,当前插件将无法展示。这种情况下可以在插件跳转之前主动申请权限。

注册权限监听事件


registerRequestPermissionTipsListener(listener)

取消注册权限监听事件

unregisterRequestPermissionTipsListener(listener)


RequestPermissionTipsListener的属性值

名称    类型    描述    必填
onRequest    (permissions:Array)=>void    申请系统权限回调,permissions为触发权限申请的所有权限    否
onConfirm    (permissions:Array)=>void    弹出系统权限授权框回调,permissions为触发弹出权限授权框的所有权限    否
onComplete    (permissions:UTSJSONObject)=>void    权限申请完成回调,permissions包括权限及权限的状态。grant为权限已获取,denied为权限已拒绝    否
setRequestPermissionTips(UTSJSONObject)
设置权限监听的说明。支持针对权限设置具体的说明。

参考:{"android.permission.CAMERA":"<p>相机权限申请说明</p>"}

安卓权限列表可参考谷歌官方文档。

权限申请说明基于原生TextView实现,可以实现加载html内容,支持的标签及属性可参考:

<b> 或 <strong>:加粗文本。
<i> 或 <em>:斜体文本。
<u>:下划线文本。
<sup>:上标文本。
<sub>:下标文本。
<tt>:等宽字体文本。
<big>:放大字体。
<small>:缩小字体。
<strike> 或 <s> 或 <del>:带有删除线的文本。
<p>:段落。
<div>:块级容器。
<h1>,<h2>,<h3>,<h4>,<h5>,<h6>:区域标题元素。
<ul>, <ol>, <li>:无序列表和有序列表。
<br>:换行。
<font color="..."> 和 <font size="...">:设置文本颜色和大小。

示例

<script>
    import {
        registerRequestPermissionTipsListener,
        unregisterRequestPermissionTipsListener,
        setRequestPermissionTips
    } from "@/uni_modules/uni-registerRequestPermissionTips"
    var PermissionTips = {
        "android.permission.CAMERA": "<h4 style=\"font-size:40px;\">正在读取通讯录权限</h4><font color=#cccccc>通讯录权限不会获取任何信息,请注意</font>",
        "android.permission.READ_PHONE_STATE": "<h4 style=\"font-size:40px;\">正在读取网络状态权限</h4><font color=#cccccc>通讯录权限不会获取任何信息,请注意通讯录权限不会获取任何信息,请注意通讯录权限不会获取任何信息,请注意</font>"
    }
    export default {
        onLaunch: function() {
            var brand = uni.getSystemInfoSync().deviceBrand
            setRequestPermissionTips(PermissionTips)
            registerRequestPermissionTipsListener({
                onRequest: (e) => {
                    console.log(e)
                },
                onConfirm: (e) => {
                    console.log(e)
                },
                onComplete: (e) => {
                    // 华为手机在权限禁止之后,再次申请权限不会出现权限申请框。此时应该引导用户去系统设置开启此权限,不应该频繁申请。
                    if (brand.toLowerCase() == "huawei") {
                        var tips = {}
                        var hasDeniedPermission = false
                        for (var k in PermissionTips) {
                            if (e[k] != "denied") {
                                tips[k] = PermissionTips[k]
                            } else {
                                hasDeniedPermission = true
                            }
                        }
                        setRequestPermissionTips(tips) // 更新弹框提醒,防止华为手机不出现权限申请框时权限提醒框闪烁的情况
                        if (hasDeniedPermission)
                            uni.showModal({
                                content: "权限已经被拒绝,请前往设置中开启"
                            })
                    }
                }
            })
        },
        onShow: function() {
            console.log('App Show')
        },
        onHide: function() {
            console.log('App Hide')
        },
        onExit: function() {
            unregisterRequestPermissionTipsListener(null)
        }
    }
</script>

相关文章:

  • Java Socket编程从零到实战详解
  • Docker 镜像、容器与数据卷的高效管理:最佳实践与自动化脚本20250411
  • 如何设置Ubuntu服务器版防火墙
  • C++ inline和define(宏)
  • DeepSeek的神经元革命:穿透搜索引擎算法的下一代内容基建
  • Redis 学习目标
  • O(n)复杂度实现寻找数组第k小的数(快速选择算法)
  • spring--整合Mybatis详解
  • 支持多格式且免费的图片转换工具推荐
  • 【Java实战】——手撕斐波那契数列
  • 成都国际数字影像产业园:以产业生态优势,驱动影像业务腾飞
  • PM2 完全指南:Node.js 应用后台启动、关闭与重启详解
  • ONVIF/RTSP/RTMP协议EasyCVR视频汇聚平台RTMP协议配置全攻略 | 直播推流实战教程
  • 蓝桥杯赛前题
  • VectorBT量化入门系列:第五章 VectorBT性能评估与分析
  • zerotier安装在旁路由实现异地局域网互访的设置方法
  • P8754 [蓝桥杯 2021 省 AB2] 完全平方数
  • 蓝桥杯比赛 python程序设计——封闭图形个数
  • 使用Lombok的@Slf4j和idea构建:找不到log符号-解决
  • ARP代理
  • 外贸网站用什么语言/怎么做自己的网站
  • 网站开发工程师是什么/河南郑州网站推广优化外包
  • 大型网站搜索怎么做的/百度站长seo
  • 医院网站推广方法/在线咨询 1 网站宣传
  • 某网站建设方案/媒介星软文平台
  • 做信息图的网站/百度百科官网首页