关于华为应用市场上架需要同步告知使用权限的解决方案(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

相关文章

使用Python提取PDF大纲(书签)的完整指南

《使用Python提取PDF大纲(书签)的完整指南》PDF大纲(Outline)​​是PDF文档中的导航结构,通常显示在阅读器的侧边栏中,方便用户快速跳转到文档的不同部分,大纲通常以层级结构组织,包含... 目录一、PDF大纲简介二、准备工作所需工具常见安装问题三、代码实现完整代码核心功能解析四、使用效果控

Linux部署中的文件大小写问题的解决方案

《Linux部署中的文件大小写问题的解决方案》在本地开发环境(Windows/macOS)一切正常,但部署到Linux服务器后出现模块加载错误,核心原因是Linux文件系统严格区分大小写,所以本文给大... 目录问题背景解决方案配置要求问题背景在本地开发环境(Windows/MACOS)一切正常,但部署到

C#异步编程ConfigureAwait的使用小结

《C#异步编程ConfigureAwait的使用小结》本文介绍了异步编程在GUI和服务器端应用的优势,详细的介绍了async和await的关键作用,通过实例解析了在UI线程正确使用await.Conf... 异步编程是并发的一种形式,它有两大好处:对于面向终端用户的GUI程序,提高了响应能力对于服务器端应

MySQL慢查询工具的使用小结

《MySQL慢查询工具的使用小结》使用MySQL的慢查询工具可以帮助开发者识别和优化性能不佳的SQL查询,本文就来介绍一下MySQL的慢查询工具,具有一定的参考价值,感兴趣的可以了解一下... 目录一、启用慢查询日志1.1 编辑mysql配置文件1.2 重启MySQL服务二、配置动态参数(可选)三、分析慢查

MYSQL中information_schema的使用

《MYSQL中information_schema的使用》information_schema是MySQL中的一个虚拟数据库,用于提供关于MySQL服务器及其数据库的元数,这些元数据包括数据库名称、表... 目录关键要点什么是information_schema?主要功能使用示例mysql 中informa

Spring Boot项目如何使用外部application.yml配置文件启动JAR包

《SpringBoot项目如何使用外部application.yml配置文件启动JAR包》文章介绍了SpringBoot项目通过指定外部application.yml配置文件启动JAR包的方法,包括... 目录Spring Boot项目中使用外部application.yml配置文件启动JAR包一、基本原理

Java中InputStream重复使用问题的几种解决方案

《Java中InputStream重复使用问题的几种解决方案》在Java开发中,InputStream是用于读取字节流的类,在许多场景下,我们可能需要重复读取InputStream中的数据,这篇文章主... 目录前言1. 使用mark()和reset()方法(适用于支持标记的流)2. 将流内容缓存到字节数组

MybatisPlus中removeById删除数据库未变解决方案

《MybatisPlus中removeById删除数据库未变解决方案》MyBatisPlus中,removeById需实体类标注@TableId注解以识别数据库主键,若字段名不一致,应通过value属... 目录MyBATisPlus中removeBypythonId删除数据库未变removeById(Se

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

gorm乐观锁使用小结

《gorm乐观锁使用小结》本文主要介绍了gorm乐观锁使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录前言grom乐观锁机制gorm乐观锁依赖安装gorm乐观锁使用创建一个user表插入数据版本号更新总结前言乐观锁,顾名