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

相关文章

SpringSecurity显示用户账号已被锁定的原因及解决方案

《SpringSecurity显示用户账号已被锁定的原因及解决方案》SpringSecurity中用户账号被锁定问题源于UserDetails接口方法返回值错误,解决方案是修正isAccountNon... 目录SpringSecurity显示用户账号已被锁定的解决方案1.问题出现前的工作2.问题出现原因各

Python的端到端测试框架SeleniumBase使用解读

《Python的端到端测试框架SeleniumBase使用解读》:本文主要介绍Python的端到端测试框架SeleniumBase使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全... 目录SeleniumBase详细介绍及用法指南什么是 SeleniumBase?SeleniumBase

Java继承映射的三种使用方法示例

《Java继承映射的三种使用方法示例》继承在Java中扮演着重要的角色,它允许我们创建一个类(子类),该类继承另一个类(父类)的所有属性和方法,:本文主要介绍Java继承映射的三种使用方法示例,需... 目录前言一、单表继承(Single Table Inheritance)1-1、原理1-2、使用方法1-

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局

Python中对FFmpeg封装开发库FFmpy详解

《Python中对FFmpeg封装开发库FFmpy详解》:本文主要介绍Python中对FFmpeg封装开发库FFmpy,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、FFmpy简介与安装1.1 FFmpy概述1.2 安装方法二、FFmpy核心类与方法2.1 FF

Android ViewBinding使用流程

《AndroidViewBinding使用流程》AndroidViewBinding是Jetpack组件,替代findViewById,提供类型安全、空安全和编译时检查,代码简洁且性能优化,相比Da... 目录一、核心概念二、ViewBinding优点三、使用流程1. 启用 ViewBinding (模块级

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp

基于Python开发Windows屏幕控制工具

《基于Python开发Windows屏幕控制工具》在数字化办公时代,屏幕管理已成为提升工作效率和保护眼睛健康的重要环节,本文将分享一个基于Python和PySide6开发的Windows屏幕控制工具,... 目录概述功能亮点界面展示实现步骤详解1. 环境准备2. 亮度控制模块3. 息屏功能实现4. 息屏时间

python使用库爬取m3u8文件的示例

《python使用库爬取m3u8文件的示例》本文主要介绍了python使用库爬取m3u8文件的示例,可以使用requests、m3u8、ffmpeg等库,实现获取、解析、下载视频片段并合并等步骤,具有... 目录一、准备工作二、获取m3u8文件内容三、解析m3u8文件四、下载视频片段五、合并视频片段六、错误

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器