关于华为应用市场上架需要同步告知使用权限的解决方案(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 OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

Python一次性将指定版本所有包上传PyPI镜像解决方案

《Python一次性将指定版本所有包上传PyPI镜像解决方案》本文主要介绍了一个安全、完整、可离线部署的解决方案,用于一次性准备指定Python版本的所有包,然后导出到内网环境,感兴趣的小伙伴可以跟随... 目录为什么需要这个方案完整解决方案1. 项目目录结构2. 创建智能下载脚本3. 创建包清单生成脚本4

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。

java.sql.SQLTransientConnectionException连接超时异常原因及解决方案

《java.sql.SQLTransientConnectionException连接超时异常原因及解决方案》:本文主要介绍java.sql.SQLTransientConnectionExcep... 目录一、引言二、异常信息分析三、可能的原因3.1 连接池配置不合理3.2 数据库负载过高3.3 连接泄漏

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java