国内大厂首次推出Android统一标准,真是威锐顾的,全套学习

本文主要是介绍国内大厂首次推出Android统一标准,真是威锐顾的,全套学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述合格用例详细说明
安装,运行及卸载
-1.应用在用户未授权情况下,不能进行程序下载、安装、或升级操作;
-2.应用在用户未授权情况下,不能执行自启动操作;
-3.应用在用户强制关闭或退出后,不能继续占用系统资源;
功能使用
-1.应用在用户未授权情况下,不能执行拨打电话、发送短信等操作;
-2.应用在用户未授权情况下,不能执行摄像、录音、截屏等操作;
-3.应用在用户未授权情况下,不能打开或关闭如WiFi、蓝牙、GPS等;
数据操作
-1.应用在用户未授权情况下,不能读写用户短信、联系人等隐私数据;
-2.应用在用户未授权情况下,不能收集或上报用户设备、系统及应用程序信息;
-3.应用在用户未授权情况下,不能修改系统配置等资源文件;
-4.应用在用户未授权情况下,不能修改其他应用程序的权限、数据等;
行为规范
-1.应用在用户未授权情况下,不能进行消费操作;
-2.应用不能包含故意破坏用户使用体验、阻碍用户正常使用手机或应用的任何行为;
-3.应用中不能包含任何侵犯用户知情权、选择权的恶意行为;
-4.应用在用户未授权情况下,不能利用漏洞等方式获取系统控制权限,进行非授权操作;
-5.如无必要的使用场景,应用不能在桌面、锁屏和其他应用上,弹出悬浮窗、自定义后台Toast、后台弹出Activity等骚扰用户的行为;1.应用锁屏通知开关处于关闭状态时,禁止在锁屏弹出任何信息。

2.仅允许导航、音乐、运动健康类应用的主功能,在锁屏上显示全屏覆盖界面;例如导航-路线导航、音乐-音乐播放、运动健康-记步轨迹。
3.在锁屏或其他应用界面上,仅允许聊天消息、短信息、闹钟等对推送有实时性要求的信息和弹出界面。
4.应用不能在未经用户主动设置或者用户主动发起时,弹出界面覆盖到桌面或其他应用之上。 |
| - | 6.如无必要的使用场景,应用不能发送无法删除的常驻通知; | 仅允许音乐、下载,在离开应用界面后,不能在通知栏显示常驻通知,导致用户无法清除。 |
| - | 7.应用不能弹出、显示影响用户体验的广告,如抬头、强制插屏、侧边等; | 1.禁止弹出任何广告界面覆盖在原有应用功能界面之上。
2.允许和原有界面功能平铺在一个界面的非弹出式广告(如微信朋友圈)。 |
| - | 8.应用不能引导用户开启开发者选项,禁止引导用户开启USB调试模式; | 开发者选项和USB调试功能属于开发者调试设备的选项,禁止应用引导用户开启。 |
| 其他标准 | | |
| - | 1.应用不能包含病毒、木马; | |
| - | 2.应用不能包含漏洞、后门; | |
| - | 3.应用不能包含国家法律禁止的内容,包括但不限于色情,赌博,或任何危害国家安全的信息; | |
| - | 4.应用不能包含其他任何形式损害用户利益及资产的行为; | |
| - | 5.应用不能通过热补丁,引入恶意行为和不符合本标准的行为; | |

3.2 开发安全标准

  • 3.2.1 Manifest和权限使用安全规范

注:权限的申请和使用应满足最小化原则。

问题描述合格用例详细说明
1.权限管理
-1)不申请不需要使用的权限,为自定义权限设置合理的安全保护级别;申请权限满足最小化原则,申请权限申请的权限全部为应用功能所需,不申请多余的权限;应用自定义权限,自行根据数据和行为的安全敏感度,设置合理的安全保护级别。
-2)应用申请的权限,都必须有明确、合理的功能和使用场景;使用权限满足最小化原则,只有使用应用的某个功能,而对应到的某个权限为该功能和合理要求时,才允许使用相应权限。比如某聊天软件,必须在进行视频聊天、拍照等功能需要的场景下,才允许使用摄像头,而在其附属的新闻浏览功能中,不允许使用摄像头。
-3)TargetSdkVersion>=23,必须适配Android M及以后版本的动态权限机制。必须适配Android M及以后版本的动态权限机制,并且强烈建议适配到Android O(TargetSdkVersion>=26)。
-4)对于非核心权限,应用不能在权限动态弹框授权提示被用户拒绝后,强制要求用户开启,包括但不限于:a.应用退出;b.弹框提醒用户打开>=2次;
2.功能项管理关闭不需要及有风险的功能选项,如数据备份功能、调试功能;
3.组件管理组件声明的合理性,避免导出不需要外部调用的组件,如需导出应设置合理的权限保护;
  • 3.2.2 应用编码安全规范
问题描述合格用例
1.基础编码安全规范1) 保证开发环境的安全性,如使用官方渠道下载的开发工具;
  1. 避免硬编码关键数据,如加密密钥、后端服务器敏感信息等;
  2. 应用代码净化,代码逻辑优化、剔除应用中的死代码块;
  3. 统一的日志管理接口,避免在日志中记录敏感信息;
  4. 应用发布之前,关闭调试接口和调试日志。 |
    | 2.系统API使用安全规范 | 1) 使用官方推荐版本的API接口,不使用系统废弃的API
  5. 熟悉并遵从安全规范,避免遗漏安全限制操作,引入安全风险;
  6. 对关键操作身份校验和权限检查; |
    | 3.第三方代码使用安全规范 | 1) 代码评估。来源可靠性评估、代码质量评估、潜在安全风险评估;
  7. 权限控制。确认引入代码所需使用的权限最小化;
  8. 更新维护。关注代码的安全动态和版本更新情况,及时修复安全问题,更新代码;
  9. 安全保护。对引入的代码进行混淆,防止攻击者针对性的攻击; |
    | 4.代码保护安全规范 | 1) 代码混淆。提高攻击者代码分析难度;
  10. 加固保护。使用自研或者第三方加固系统进行应用加固,进行代码隐藏和加密保护; |
  • 3.2.3 数据安全规范
问题描述合格用例
1.数据加密安全规范1) 数据密文和加密密钥应存放在不同的位置;
  1. 密钥存储模块应具备防调试及反编译的能力;
  2. 密钥数据应分散存储,为获取密钥密文增大难度 |
    | 2.数据存储安全规范 | 1) 应用程序关键数据应该存放在私有目录下,并设置合理的访问权限;
  3. 应用程序中的隐私数据应加密存储。用于加密的密钥应妥善保存;
  4. 禁止程序运行日志中包含有用户敏感数据、程序调试数据等; |
    | 3.数据使用安全规范 | 1) 数据合法性保护。控制用户输入数据的类型、长度,进行恶意代码过滤等;
  5. 数据完整和有效性保护。对于接收到的外部数据、加载的外部文件,进行完整、有效性性检查; |
  • 3.2.4 通信安全
问题描述合格用例
1.本地通信安全1) intent数据安全。避免在intent包含用户敏感数据,从intent中获取数据时加入必要的异常处理;
  1. intent scheme url 协议安全。使用过程中加入安全限制,防止UXSS等安全问题;
  2. 组件调用方式安全。避免通过隐式方式进行调用组件,防止组件劫持;
  3. 本地socket通信安全。避免是使用socket方式进行本地通信,如需使用,localhost端口号随机生成,并对端口连接对象进行身份认证和鉴权; |
    | 2.远程通信安全 | 1) 使用https代替http进行通信,并对https证书进行严格校验;
  4. 避免进行远程端口开发通信,如需使用,需要对端口连接对象进行身份认证和鉴权; |
  • 3.2.5 业务安全
问题描述合格用例
1.认证和授权1) 认证和授权过程应在服务器端完成,避免客户端绕过问题;
  1. 对于涉及敏感信息的服务,每次使用前需进行身份认证;
  2. 控制登录凭证token有效期,通信过程中进行token鉴权;
  3. 避免在终端设备上使用不安全的方法来存储用户名、口令及其它登录凭证;
  4. 用户密码需要使用强不可逆的加密算法加密后传输,并引入salt,提高破解难度;
  5. 账户号和终端设备信息进行绑定,防止终端模拟攻击; |
    | 2.业务逻辑及数据安全 | 1) 条件判断。确保逻辑过程中前置判断条件的有效性、不可绕 过性,防止攻击者进行数据修改绕过安全限制;
  6. 逻辑设计。确保业务逻辑设计、分支条件及边界条件处理的正确性和完备性,防止不可控执行流程;
  7. 工作分配。确保服务端和客户端分工正确,防止一些应该放在服务端的校验工作设置在了客户端,造成权限校验绕过;
  8. 业务数据。关键业务数据防篡改、防伪造、防重放;
  9. 短信验证码安全。禁止验证码回传行为,验证码至少6位,同时严格限定验证码时效; |
    | 3.业务运维安全 | 1) 业务风险监控、预警、异常处理预案;
  10. 安全动态跟踪及预警、安全事件排查、漏洞修复; |
  • 3.2.6 运行环境安全
问题描述合格用例
运行环境安全1) 运行期重打包检测;
  1. 模拟器运行环境检测;
  2. 调试、注入操作监控;
  3. root环境运行检测; |
  • 3.2.7 隐私安全
问题描述合格用例
隐私安全1) 涉及到应用下载软件、对用户系统或软件升级等修改用户个人空间的行为,须得到用户的同意
  1. 收集或使用个人数据前,须明确提示用户,并获得用户的明示同意,并且允许用户随时关闭对个人数据的收集和使用
  2. 默认禁止收集数据主体的敏感个人数据,除非业务必需(如:运动健康类业务)或为了满足法律与监管机构要求可收集和处理(含profiling),并且同意应该单独收集
  3. 应提供对用户的同意和撤销同意行为进行记录的机制
  4. 隐私声明内容发生变化时,须告知用户查看并获得用户同意
  5. 个人数据收集范围、使用目的不得超出隐私声明,且遵循最小化原则,当个人数据的采集范围、使用目的发生变更时,应及时更新隐私声明
  6. 于存储个人数据的系统,需对存储的个人数据定义存留期
  7. 数据主体撤销同意之后,产品必须禁止继续收集和处理其相应个人数据
  8. 将数据主体个人数据提供给第三方前,必须获得数据主体的同意
  9. 推送的内容(含广告)必须是符合政治、法律和宗教要求,并且推送频度不能干扰用户正常使用
  10. 第三方应用软件调用移动智能终端敏感功能时,应先获得用户明确同意
  11. 第三方应用软件对用户数据操作时,应先获得用户明确同意
  12. 应用软件不得申请和调用与提供服务无关的终端功能 |
(4)功耗标准
问题描述判定标准合格用例特殊考虑事项
后台处理器占用测量应用在后台时对处理器的占用及Wake Lock设置情况1. 平均每小时占用处理器累计时间不超过90秒,即处理器平均占用率不超过2.5%
2. 禁止应用设置WakeLock以下场景除外:

1. 后台播放视频、音乐或观看直播时
2. 后台导航时
3. 后台下载视频、音乐或离线地图时
4. 后台进行收发消息、游戏挂机时
5. 后台欺诈拦截、网络安全扫描、流量监控、定时提醒时 |
| 后台屏幕占用 | 测量应用在后台时对屏幕的占用 | 1. 不允许一切后台应用阻止屏幕自动变暗或关闭
2. 不允许应用在屏幕变暗或关闭时点亮屏幕 | 以下场景除外:后台收发消息、定时提醒时 |
| 后台无线网络占用 | 测量应用在后台时对无线网络的占用
(无线网络包括:Wi-Fi、数据连接、蓝牙及红外等无线信号网络。) | 1. 平均每小时使用无线网络传输数据时间不超过5分钟
2. 平均每小时对无线网络的扫描不超过60次 | 以下场景除外:
1. 后台播放在线视频、音乐或观看直播时
2. 后台导航时
3. 后台下载视频、音乐或离线地图时
4. 后台进行收发消息时
5. 后台欺诈拦截、网络安全扫描或流量监控时 |
| 后台音频设备占用 | 测量应用在后台时对音频设备的占用 | 禁止此情况下应用使用麦克风或扬声器 | 以下场景除外:
1. 后台播放在线视频、音乐或观看直播时
2. 后台导航时
3. 后台定时提醒时 |
| 后台摄像头占用 | 测量应用在后台时对摄像头的占用
(摄像头包含:前置摄像头、后置摄像头、红外摄像头及闪光灯) | 禁止此情况下应用使用摄像头或闪光灯 | |
| 后台定位传感器占用 | 测量应用在后台时对定位传感器的占用 | 禁止此情况下应用使用定位传感器 | 以下场景除外:
1. 后台导航时2. 后台轨迹追踪时
3. 后台下载离线地图时 |
| 后台动作传感器占用 | 测量应用在后台时对动作传感器的占用 | 禁止此情况下应用使用动作传感器 | 以下场景除外:
1. 后台导航时
2. 后台记步时 |
| 后台Alarm占用 | 测量应用在后台时对Alarm的占用 | 平均每小时通过Alarm调起的次数不超过20次 | 以下场景除外:
1. 后台播放视频时
2. 后台收发消息时 |

(5)性能标准

5.1 适用范围

应用类型核心场景
便捷生活类进入应用主功能界面
出行导航类进入位置搜索页面
购物比价类进入购物首页,页面含商品列表、搜索栏等。
拍摄美化进入应用主功能界面
社交通讯类登陆后进入主界面收/发消息 或:登陆后进入主界面
实用工具邮箱类:启动应用 - 登陆邮箱 - 收取邮件(邮箱内已有邮件列表超过10封)
新闻阅读类启动应用 - 进入首页 - 刷新新闻列表 -滑动新闻列表
学习办公进入应用主功能界面
影音娱乐进入应用主功能界面
游戏进入应用主功能界面

5.2 性能测试标准

问题描述判定标准合格用例

这篇关于国内大厂首次推出Android统一标准,真是威锐顾的,全套学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss