关于华为应用市场上架需要同步告知使用权限的解决方案(uniapp适用,原生开发思路同理),直接复制粘贴!

本文主要是介绍关于华为应用市场上架需要同步告知使用权限的解决方案(uniapp适用,原生开发思路同理),直接复制粘贴!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

最近华为应用市场审核的时候加了一条新规具体如下:

您的应用在运行时,未同步告知权限申请的使用目的,向用户索取(存储、相机、位置信息)等权限,不符合华为应用市场审核标准。
测试步骤:点击在线聊-拍照/图片,申请存储、相机权限;点击首页-地图找房,申请位置信息权限。
修改建议:APP在调用终端敏感权限时,应同步说明权限申请的使用目的,包括但不限于申请权限的名称、服务的具体功能、用途;告知方式不限于弹窗、蒙层、浮窗、或者自定义操作系统权限弹框等。请排查应用内所有权限申请行为,确保均符合要求。
请参考《审核指南》第7.21相关审核要求:https://developer.huawei.com/consumer/cn/doc/app/50104-07#h3-1683701612940-2
APP常见个人信息保护问题FAQ请参考:https://developer.huawei.com/consumer/cn/doc/app/FAQ-faq-05#h1-1698326401789-0
测试环境:Wi-Fi联网、HonmonyOS 2.0(Nova5)、中文环境。

我在本篇博客说说简单的处理方式,网上其他人写的太复杂了,亲测可上线

先看效果

在这里插入图片描述

封装权限判断工具类

新建一个authorizeUtils.ts文件,直接无脑复制如下代码:

const checkIsIos = async () => {return new Promise((resolve => {uni.getSystemInfo({success: function (res) {resolve(systemInfo.value.platform === "ios")}});}))
}
export default class authorizeUtils {/*** 授权前告知用户使用意图* @param content * @returns */static showAuthTipModal = async (authorize: string) => {// #ifdef H5if (1 === 1) {return true}// #endif// ios端在manifest.json配置权限使用说明,以下权限判断仅在安卓端可用let isIos = await checkIsIos()if (isIos) return truelet compat: any = plus.android.importClass('androidx.core.content.ContextCompat')let context = plus.android.runtimeMainActivity()let result = compat.checkSelfPermission(context, authorize)console.log("result===", result);if (result === 0) return true// // 如果已经授权直接返回const contentData = {['android.permission.ACCESS_FINE_LOCATION']: {title: "定位权限说明",describe: "便于您使用该功能在地图找房中根据您的位置检索附近的房源,请您确认授权,否则无法使用该功能"},["android.permission.READ_EXTERNAL_STORAGE"]: {title: "相册权限说明",describe: "便于您使用该功能上传您的照片/图片/视频及用户实名认证信息、发布房源时上传图片,请您确认授权,否则无法使用该功能"},["android.permission.CAMERA"]: {title: "拍摄权限说明",describe: "便于您使用该功能拍摄身份证、房源、头像、房产证等信息,请您确认授权,否则无法使用该功能"},["android.permission.CALL_PHONE"]: {title: "拨打电话权限说明",describe: "便于您使用该功能拨打房东、经纪人、管家、客服电话,请您确认授权,否则无法使用该功能"},}return new Promise((resolve) => {uni.showModal({title: contentData[authorize].title,content: contentData[authorize].describe,success: (res) => {resolve(!!res.confirm)},fail: () => {}})})}/*** 用户拒绝授权提示手动授权*/static showManualAuth = async (authorize: string) => {let isIos = await checkIsIos()if (isIos) return trueconst contentData = {['android.permission.ACCESS_FINE_LOCATION']: "获取定位权限失败,请手动打开授权或检查系统定位开关",["android.permission.READ_EXTERNAL_STORAGE"]: "获取相册权限失败,请手动打开授权",["android.permission.CAMERA"]: "获取拍摄权限失败,请手动打开授权",["android.permission.CALL_PHONE"]: "获取拨打电话权限失败,请手动打开授权",}uni.showModal({title: '提示',content: contentData[authorize],confirmText: "去设置",success: (res) => {if (res.confirm) {uni.openAppAuthorizeSetting({success(res) {console.log(res);}});}if (res.cancel) {console.log('用户点击取消');}}});}
}

工具类的使用示例

拨打电话示例:

   // 检查是否授权拨打电话权限let flag = await authorizeUtils.showAuthTipModal("android.permission.CALL_PHONE")// 用户拒绝授权if (!flag) returnuni.makePhoneCall({phoneNumber, fail: () => {// 权限开启失败提示用户手动打开权限authorizeUtils.showManualAuth("android.permission.CALL_PHONE")}});

获取用户位置信息示例:

    getUserLocation = async (): Promise<null | { longitude: number, latitude: number }> => {return new Promise(async (resolve) => {let authFlag = await authorizeUtils.showAuthTipModal("android.permission.ACCESS_FINE_LOCATION")if (!authFlag) return resolve(null)uni.getLocation({type: "wgs84",success: ({ longitude, latitude }) => {return resolve({ longitude, latitude })},fail: (fail) => {this.hideLoading()authorizeUtils.showManualAuth("android.permission.ACCESS_FINE_LOCATION")return resolve(null)}});})}

注意

app端选择图片方法chooseImage,默认是弹出选项拍照和从相册选择,但是拍照和从相册选择是两种不同的权限,所以这个弹出选项需要自己手动写,用户选择拍照就请求相机权限,从相册选择就请求存储权限,我这边附上我的代码,仅供参考:

const handleUpload = async (openType: "camera" | "album") => {if (props.disabled) return;// #ifdef APP-PLUSconst permissionType = openType === "album" ? "android.permission.READ_EXTERNAL_STORAGE" : "android.permission.CAMERA";let authFlag = await authorizeUtils.showAuthTipModal(permissionType);if (!authFlag) return;// #endifuni.chooseImage({sourceType: [openType],count: props.limit,success: async (success) => {},fail: (fail) => {if ([0, 11, 12].includes(fail.code)) return;authorizeUtils.showManualAuth(permissionType);}});
};

安卓权限列表

// android.permission.ACCESS_FINE_LOCATION	位置权限
// android.permission.ACCESS_COARSE_LOCATION	模糊位置权限(蓝牙\ble依赖)
// android.permission.CAMERA	摄像头权限
// android.permission.READ_EXTERNAL_STORAGE	外部存储(含相册)读取权限
// android.permission.WRITE_EXTERNAL_STORAGE	外部存储(含相册)写入权限
// android.permission.RECORD_AUDIO	麦克风权限
// android.permission.READ_CONTACTS	通讯录读取权限
// android.permission.WRITE_CONTACTS	通讯录写入权限
// android.permission.READ_CALENDAR	日历读取权限
// android.permission.WRITE_CALENDAR	日历写入权限
// android.permission.READ_SMS	短信读取权限
// android.permission.SEND_SMS	短信发送权限
// android.permission.RECEIVE_SMS	接收新短信权限
// android.permission.READ_PHONE_STATE	获取手机识别码等信息的权限
// android.permission.CALL_PHONE	拨打电话权限
// android.permission.READ_CALL_LOG	获取通话记录权限

总结

打工人何苦为难打工人!!

这篇关于关于华为应用市场上架需要同步告知使用权限的解决方案(uniapp适用,原生开发思路同理),直接复制粘贴!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/603713

相关文章

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

如何使用Nginx配置将80端口重定向到443端口

《如何使用Nginx配置将80端口重定向到443端口》这篇文章主要为大家详细介绍了如何将Nginx配置为将HTTP(80端口)请求重定向到HTTPS(443端口),文中的示例代码讲解详细,有需要的小伙... 目录1. 创建或编辑Nginx配置文件2. 配置HTTP重定向到HTTPS3. 配置HTTPS服务器

Python结合PyWebView库打造跨平台桌面应用

《Python结合PyWebView库打造跨平台桌面应用》随着Web技术的发展,将HTML/CSS/JavaScript与Python结合构建桌面应用成为可能,本文将系统讲解如何使用PyWebView... 目录一、技术原理与优势分析1.1 架构原理1.2 核心优势二、开发环境搭建2.1 安装依赖2.2 验

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自