Android améliore en permanence ses fonctionnalités et ses offres de sécurité. Consultez les listes des améliorations par version dans le panneau de navigation de gauche.
Android 14
每个 Android 版本中都包含数十种安全增强功能,以保护用户。以下是 Android 14 中提供的一些主要安全增强功能:
- Android 10 中引入的硬件辅助 AddressSanitizer (HWASan) 是一款类似于 AddressSanitizer 的内存错误检测工具。Android 14 对 HWASan 进行了重大改进。如需了解它如何帮助防止 bug 进入 Android 版本,请访问 HWAddressSanitizer
- 在 Android 14 中,从与第三方共享位置数据的应用开始,系统运行时权限对话框现在包含一个可点击的部分,用于突出显示应用的数据分享做法,包括诸如以下信息:应用为什么可能会决定与第三方分享数据。
- Android 12 引入了在调制解调器级别停用 2G 支持的选项,以保护用户免受 2G 的过时安全模型固有的安全风险的影响。认识到停用 2G 对企业客户的重要性后,Android 14 在 Android Enterprise 中启用了此安全功能,以便 IT 管理员能够限制受管设备降级到 2G 连接。
- 开始支持拒绝未加密的移动网络连接,确保电路交换语音和短信流量始终会加密,并可防范被动无线拦截。详细了解 Android 的移动网络连接强化计划。
- 新增了对多个 IMEI 的支持
- 从 Android 14 开始,AES-HCTR2 是采用加速加密指令的设备的首选文件名加密模式。
- 移动网络连接
- 在 Android 安全中心添加了相关文档
- 如果您的应用以 Android 14 为目标平台并使用动态代码加载 (DCL) 功能,则必须将所有动态加载的文件标记为只读。否则,系统会抛出异常。我们建议应用尽可能避免动态加载代码,因为这样做会大大增加应用因代码注入或代码篡改而遭到入侵的风险。
Android 13
Chaque version d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des principales améliorations de sécurité disponibles dans Android 13:
- Android 13 est compatible avec les présentations multi-documents. Cette nouvelle interface de session de présentation permet à une application de réaliser une présentation multi-documents, ce qui n'est pas possible avec l'API existante. Pour en savoir plus, consultez la section Identifiant d'identité.
- Dans Android 13, les intents provenant d'applications externes sont transmis à un composant exporté si et seulement si les intents correspondent à leurs éléments de filtre d'intent déclarés.
- L'API Open Mobile (OMAPI) est une API standard utilisée pour communiquer avec l'élément sécurisé d'un appareil. Avant Android 13, seules les applications et les modules de framework avaient accès à cette interface. En le convertissant en interface stable du fournisseur, les modules HAL peuvent également communiquer avec les éléments sécurisés via le service OMAPI. Pour en savoir plus, consultez la page Interface stable du fournisseur OMAPI.
- À partir d'Android 13-QPR, les UID partagés sont obsolètes. Les utilisateurs d'Android 13 ou version ultérieure doivent ajouter la ligne "android:sharedUserMaxSdkVersion="32"" dans leur fichier manifeste. Cette entrée empêche les nouveaux utilisateurs d'obtenir un UID partagé. Pour en savoir plus sur les UID, consultez la section Signature d'application.
- Android 13 prend désormais en charge les primitives cryptographiques symétriques Keystore telles que l'AES (Advanced Encryption Standard), le HMAC (Keyed-Hash Message Authentication Code) et les algorithmes cryptographiques asymétriques (y compris les courbes elliptiques, RSA2048, RSA4096 et Curve 25519).
- Android 13 (niveau d'API 33) ou version ultérieure prend en charge une autorisation d'exécution pour l'envoi de notifications non exemptées depuis une application. Cela permet aux utilisateurs de contrôler les notifications d'autorisation qu'ils voient.
- Ajout d'une invite par utilisation pour les applications qui demandent à accéder à tous les journaux de l'appareil, ce qui permet aux utilisateurs d'autoriser ou de refuser l'accès.
- a lancé le framework de virtualisation Android (AVF), qui rassemble différents hyperviseurs dans un même framework avec des API standardisées. Il fournit des environnements d'exécution sécurisés et privés pour exécuter des charges de travail isolées par un hyperviseur.
- Introduction du schéma de signature APK v3.1. Toutes les nouvelles rotations de clés qui utilisent apksigner utilisent le schéma de signature v3.1 par défaut pour cibler la rotation pour Android 13 et versions ultérieures.
Consultez les notes de version complètes d'AOSP et la liste des fonctionnalités et modifications pour les développeurs Android.
Android 12
每个 Android 版本中都包含数十种用于保护用户的安全增强功能。以下是 Android 12 中提供的一些主要安全增强功能:
- Android 12 引入了 BiometricManager.Strings API,它为使用 BiometricPrompt 进行身份验证的应用提供本地化的字符串。这些字符串旨在感知设备,并更明确地指定可以使用哪些身份验证类型。Android 12 还支持屏下指纹传感器
- 添加了对屏下指纹传感器的支持
- 引入了 Fingerprint Android 接口定义语言 (AIDL)
- 支持新的 Face AIDL
- 引入了 Rust 作为平台开发语言
- 添加了可供用户仅授权应用访问其大致位置信息的选项
- 当应用使用摄像头或麦克风时,现在状态栏上会显示隐私指示标志
- Android 的 Private Compute Core (PCC)
- 添加了用于停用 2G 支持的选项
Android 11
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。如需查看 Android 11 中提供的一些主要安全增强功能的列表,请参阅 Android 版本说明。
Android 10
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。Android 10 包含多项安全和隐私增强功能。如需查看 Android 10 中变化的完整列表,请参阅 Android 10 版本说明。
安全性
BoundsSanitizer
Android 10 在蓝牙和编解码器中部署了 BoundsSanitizer (BoundSan)。BoundSan 使用 UBSan 的边界排错程序。该缓解功能在各个模块级别启用,有助于确保 Android 关键组件的安全性,因此不应停用。以下编解码器启用了 BoundSan:
libFLAC
libavcdec
libavcenc
libhevcdec
libmpeg2
libopus
libvpx
libspeexresampler
libvorbisidec
libaac
libxaac
只执行内存
默认情况下,AArch64 系统二进制文件的可执行代码部分会被标记为只执行(不可读取),作为应对即时代码重用攻击的安全强化缓解方法。将数据和代码混合在一起的代码以及有目的地检查这些部分的代码(无需首先将内存段重新映射为可读)将不再起作用。如果目标 SDK 为 Android 10(API 级别 29 或更高)的应用尝试读取内存中已启用只执行内存 (XOM) 的系统库的代码部分,而未首先将该部分标记为可读,则此类应用将会受到影响。
扩展访问权限
可信代理是 Smart Lock 等三重身份验证机制使用的底层机制,只能在 Android 10 中延长解锁时间。可信代理无法再解锁已锁定的设备,并且最多只能将设备解锁状态维持四个小时。
人脸识别身份验证
借助人脸识别身份验证功能,用户只需将面孔对准设备正面即可将其解锁。Android 10 添加了对一种全新人脸识别身份验证堆栈的支持,该堆栈可安全处理相机帧,从而在支持的硬件上进行人脸识别身份验证时保障安全和隐私。Android 10 还提供了一种快捷的方式来集成符合安全标准的实现方案,让人们能通过集成应用来处理一些事务(如网上银行或其他服务)。
整数溢出排错功能
Android 10 在软件编解码器中启用了整数溢出排错功能 (IntSan)。确保播放性能对于设备硬件中不支持的任何编解码器而言都在接受范围内。 以下编解码器启用了 IntSan:
libFLAC
libavcdec
libavcenc
libhevcdec
libmpeg2
libopus
libvpx
libspeexresampler
libvorbisidec
模块化系统组件
Android 10 采用模块化方式处理一些 Android 系统组件,使其能够在 Android 的常规发布周期外的时间进行更新。下面列举了几种模块:
- Android 运行时
- Conscrypt
- DNS 解析器
- DocumentsUI
- ExtServices
- 媒体
- ModuleMetadata
- 网络
- PermissionController
- 时区数据
OEMCrypto
Android 10 使用 OEMCrypto API 版本 15。
Scudo
Scudo 是一个动态的用户模式内存分配器,旨在提高遇到堆相关漏洞时的复原能力。它提供了标准 C 分配和取消分配基元,以及 C++ 基元。
ShadowCallStack
ShadowCallStack
(SCS)
是一种 LLVM 插桩模式,可将函数的返回地址保存到非叶函数的函数 prolog 中单独分配的 ShadowCallStack
实例,并从函数 epilog 中的 ShadowCallStack
实例加载返回地址,从而防止返回地址覆盖(比如堆栈缓冲区溢出)。
WPA3 和 Wi-Fi Enhanced Open
Android 10 添加了对 Wi-Fi Protected Access 3 (WPA3) 和 Wi-Fi Enhanced Open 安全标准的支持,可更好地保护隐私,更稳健地防御已知攻击。
隐私设置
以 Android 9 或更低版本为目标平台时的应用访问权限
如果您的应用在 Android 10 或更高版本上运行,但其目标平台是 Android 9(API 级别 28)或更低版本,则 Android 平台具有以下行为:
- 如果您的应用为
ACCESS_FINE_LOCATION
或ACCESS_COARSE_LOCATION
声明了<uses-permission>
元素,则系统会在安装期间自动为ACCESS_BACKGROUND_LOCATION
添加<uses-permission>
元素。 - 如果您的应用请求了
ACCESS_FINE_LOCATION
或ACCESS_COARSE_LOCATION
,系统会自动将ACCESS_BACKGROUND_LOCATION
添加到请求中。
后台 Activity 限制
从 Android 10 开始,系统会增加针对从后台启动 Activity 的限制。此项行为变更有助于最大限度地减少对用户造成的干扰,并且可以让用户更好地控制其屏幕上显示的内容。只要您的应用启动 activity 是因用户互动直接引发的,该应用就极有可能不会受到这些限制的影响。
如需详细了解从后台启动 activity 的建议替代方法,请参阅有关如何在应用中提醒用户注意有时效性的事件的指南。
相机元数据
Android 10 更改了 getCameraCharacteristics()
方法默认返回的信息的广度。具体而言,您的应用必须具有 CAMERA
权限才能访问此方法的返回值中可能包含的设备特定元数据。
如需详细了解这些变更,请参阅关于需要权限的相机字段的部分。
剪贴板数据
对于 Android 10 或更高版本,除非您的应用是默认输入法 (IME) 或是目前聚焦的应用,否则它无法访问剪贴板中的数据。
设备位置
为了让用户更好地控制应用对位置信息的访问权限,Android 10 引入了 ACCESS_BACKGROUND_LOCATION
权限。
不同于 ACCESS_FINE_LOCATION
和 ACCESS_COARSE_LOCATION
权限,ACCESS_BACKGROUND_LOCATION
权限仅会影响应用在后台运行时对位置信息的访问权限。除非符合以下条件之一,否则应用将被视为在后台访问位置信息:
- 属于该应用的 Activity 可见。
- 该应用运行的某个前台服务已声明前台服务类型为
location
。
如需将应用中的某个服务声明为前台服务类型,请将应用的targetSdkVersion
或compileSdkVersion
设置为29
或更高版本。详细了解前台服务如何继续执行用户发起的需要访问位置信息的操作。
外部存储空间
默认情况下,以 Android 10 及更高版本为目标平台的应用在访问外部存储设备中的文件时存在范围限制,即分区存储。此类应用可以查看外部存储设备内以下类型的文件,无需请求任何与存储相关的用户权限:
- 特定于应用的目录中的文件(使用
getExternalFilesDir()
访问)。 - 应用创建的照片、视频和音频片段(通过媒体库访问)。
如需详细了解分区存储以及如何共享、访问和修改在外部存储设备上保存的文件,请参阅有关如何管理外部存储设备中的文件以及如何访问和修改媒体文件的指南。
随机分配 MAC 地址
默认情况下,在搭载 Android 10 或更高版本的设备上,系统会传输随机分配的 MAC 地址。
如果您的应用处理企业使用场景,Android 平台会提供 API,用于执行与 MAC 地址相关的几个操作。
- 获取随机分配的 MAC 地址:设备所有者应用和资料所有者应用可以通过调用
getRandomizedMacAddress()
检索分配给特定网络的随机分配 MAC 地址。 - 获取实际的出厂 MAC 地址:设备所有者应用可以通过调用
getWifiMacAddress()
检索设备的实际硬件 MAC 地址。此方法对于跟踪设备队列非常有用。
不可重置的设备标识符
从 Android 10 开始,应用必须具有 READ_PRIVILEGED_PHONE_STATE
特许权限才能访问设备的不可重置标识符(包括 IMEI 和序列号)。
Build
TelephonyManager
如果您的应用没有该权限,但您仍尝试查询不可重置标识符的相关信息,则 Android 平台的响应会因目标 SDK 版本而异:
- 如果应用以 Android 10 或更高版本为目标平台,则会发生
SecurityException
。 - 如果应用以 Android 9(API 级别 28)或更低版本为目标平台,则相应方法会返回
null
或占位符数据(如果应用具有READ_PHONE_STATE
权限)。否则,会发生SecurityException
。
身体活动识别
Android 10 针对需要检测用户步数或对用户的身体活动(例如步行、骑车或坐车)进行分类的应用引入了 android.permission.ACTIVITY_RECOGNITION
运行时权限。此项权限旨在让用户了解设备传感器数据在“设置”中的使用方式。
除非用户已向您的应用授予此权限,否则 Google Play 服务中的一些库(例如 Activity Recognition API 和 Google Fit API)不会提供结果。
设备上要求您声明此权限的内置传感器只有计步器和步测器传感器。
如果您的应用以 Android 9(API 级别 28)或更低版本为目标平台,只要您的应用满足以下各项条件,系统会根据需要自动向您的应用授予 android.permission.ACTIVITY_RECOGNITION
权限:
- 清单文件包含
com.google.android.gms.permission.ACTIVITY_RECOGNITION
权限。 - 清单文件不包含
android.permission.ACTIVITY_RECOGNITION
权限。
如果系统自动授予 android.permission.ACTIVITY_RECOGNITION
权限,当您将应用更新为以 Android 10 为目标平台后,您的应用会保留此权限。但是,用户可以随时在系统设置中撤消此权限。
/proc/net 文件系统限制
在搭载 Android 10 或更高版本的设备上,应用无法访问 /proc/net
,包括与设备的网络状态相关的信息。需要访问此信息的应用(如 VPN)应使用 NetworkStatsManager
或 ConnectivityManager
类。
从界面中移除了权限组
从 Android 10 开始,应用无法在界面中查询权限的分组方式。
移除了联系人关系密切程度
从 Android 10 开始,平台不再记录联系人的关系密切程度信息。因此,如果您的应用对用户的联系人进行搜索,系统将不会按互动频率对搜索结果排序。
有关 ContactsProvider
的指南包含一项说明特定字段和方法已废弃的声明(从 Android 10 开始,这些字段和方法在所有设备上已作废)。
限制对屏幕内容的访问
为了保护用户的屏幕内容,Android 10 更改了 READ_FRAME_BUFFER
、CAPTURE_VIDEO_OUTPUT
和 CAPTURE_SECURE_VIDEO_OUTPUT
权限的作用域,从而禁止以静默方式访问设备的屏幕内容。从 Android 10 开始,这些权限只能通过签名访问。
需要访问设备屏幕内容的应用应使用 MediaProjection
API,此 API 会显示要求用户同意访问的提示。
USB 设备序列号
如果您的应用以 Android 10 或更高版本为目标平台,则该应用只能在用户授予其访问 USB 设备或配件的权限后才能读取序列号。
如需详细了解如何使用 USB 设备,请参阅有关如何配置 USB 主机的指南。
Wi-Fi
以 Android 10 或更高版本为目标平台的应用无法启用或停用 Wi-Fi。WifiManager.setWifiEnabled()
方法始终返回 false
。
如果您需要提示用户启用或停用 Wi-Fi,请使用设置面板。
对直接访问已配置的 Wi-Fi 网络实施了限制
为了保护用户隐私,只有系统应用和设备政策控制者 (DPC) 支持手动配置 Wi-Fi 网络列表。给定 DPC 可以是设备所有者,也可以是资料所有者。
如果应用以 Android 10 或更高版本为目标平台,并且应用不是系统应用或 DPC,则下列方法不会返回有用数据:
getConfiguredNetworks()
方法始终返回空列表。- 每个返回整数值的网络操作方法(
addNetwork()
和updateNetwork()
)始终返回 -1。 - 每个返回布尔值的网络操作(
removeNetwork()
、reassociate()
、enableNetwork()
、disableNetwork()
、reconnect()
和disconnect()
)始终返回false
。
Android 9
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。如需 Android 9 中提供的一些主要安全增强功能的列表,请参阅 Android 版本说明。
Android 8
Chaque version d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des principales améliorations de sécurité disponibles dans Android 8.0:
- Chiffrement. Ajout de la prise en charge de l'éviction de la clé dans le profil professionnel.
- Démarrage validé Ajout d'Android Verified Boot (AVB). Code de base de démarrage validé compatible avec la protection de rollback à utiliser dans les bootloaders ajouté à AOSP. Recommandation de prise en charge du bootloader pour la protection contre le rollback du HLOS. Nous recommandons que les bootloaders ne puissent être déverrouillés que par l'utilisateur qui interagit physiquement avec l'appareil.
- Écran de verrouillage Prise en charge de l'utilisation de matériel protégé contre les accès non autorisés pour valider les identifiants de l'écran de verrouillage.
- KeyStore. Attestation de clé obligatoire pour tous les appareils livrés avec Android 8.0 ou version ultérieure. Prise en charge de l'attestation d'identité pour améliorer l'enregistrement sans contact.
- Bac à sable. De nombreux composants sont plus étroitement isolés à l'aide de l'interface standard de Project Trebol entre le framework et les composants spécifiques à l'appareil. Application du filtrage seccomp à toutes les applications non approuvées pour réduire la surface d'attaque du kernel. WebView est désormais exécuté dans un processus isolé avec un accès très limité au reste du système.
- Renforcement du noyau. Implémentation de la copie utilisateur renforcée, de l'émulation PAN, de la lecture seule après l'initialisation et de KASLR.
- Renforcement de l'espace utilisateur. Implémentation du CFI pour la pile multimédia. Les superpositions d'application ne peuvent plus recouvrir les fenêtres critiques du système, et les utilisateurs peuvent les ignorer.
- Mise à jour de l'OS en streaming Activation des mises à jour sur les appareils dont l'espace disque est limité.
- Installer des applications inconnues Les utilisateurs doivent autoriser l'installation d'applications à partir d'une source autre qu'une plate-forme de téléchargement d'applications propriétaire.
- Confidentialité L'ID Android (SSAID) a une valeur différente pour chaque application et chaque utilisateur de l'appareil. Pour les applications de navigateur Web, l'ID client Widevine renvoie une valeur différente pour chaque nom de package d'application et origine Web.
net.hostname
est désormais vide et le client DHCP n'envoie plus de nom d'hôte.android.os.Build.SERIAL
a été remplacé par l'APIBuild.SERIAL
, qui est protégée par une autorisation contrôlée par l'utilisateur. Amélioration du changement aléatoire d'adresse MAC dans certains chipsets.
Android 7
Chaque version d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des principales améliorations de sécurité disponibles dans Android 7.0:
- Chiffrement basé sur les fichiers. Le chiffrement au niveau des fichiers, au lieu de chiffrer l'ensemble de l'espace de stockage en tant qu'unité unique, isole et protège mieux les utilisateurs et les profils individuels (par exemple, personnel et professionnel) sur un appareil.
- Démarrage direct Activé par le chiffrement basé sur les fichiers, le démarrage direct permet à certaines applications telles que le réveil et les fonctionnalités d'accessibilité de s'exécuter lorsque l'appareil est allumé, mais pas déverrouillé.
- Démarrage validé Le démarrage validé est désormais appliqué de manière stricte pour empêcher le démarrage des appareils compromis. Il est compatible avec la correction d'erreurs pour améliorer la fiabilité contre la corruption de données non malveillante.
- SELinux La mise à jour de la configuration SELinux et l'augmentation de la couverture seccomp verrouillent davantage le bac à sable d'application et réduisent la surface d'attaque.
- Randomisation de l'ordre de chargement des bibliothèques et amélioration de l'ASLR Une plus grande randomisation rend certaines attaques de réutilisation de code moins fiables.
- Renforcement du noyau. Ajout d'une protection de la mémoire supplémentaire pour les noyaux plus récents en marquant des parties de la mémoire du noyau comme en lecture seule, en limitant l'accès du noyau aux adresses de l'espace utilisateur et en réduisant encore la surface d'attaque existante.
- APK Signature Scheme v2 Introduction d'un schéma de signature de l'intégralité du fichier qui améliore la vitesse de validation et renforce les garanties d'intégrité.
- Magasin de certificats d'autorité de certification approuvés Pour permettre aux applications de contrôler plus facilement l'accès à leur trafic réseau sécurisé, les autorités de certification installées par l'utilisateur et celles installées via les API Device Admin ne sont plus approuvées par défaut pour les applications ciblant le niveau d'API 24 ou version ultérieure. De plus, tous les nouveaux appareils Android doivent être livrés avec le même magasin d'autorités de certification approuvé.
- Network Security Config (Configuration de la sécurité réseau) Configurez la sécurité réseau et TLS via un fichier de configuration déclaratif.
Android 6
Chaque version d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des principales améliorations de sécurité disponibles dans Android 6.0:
- Autorisations d'exécution Les applications demandent des autorisations au moment de l'exécution au lieu d'être accordées au moment de l'installation de l'application. Les utilisateurs peuvent activer et désactiver les autorisations pour les applications M et antérieures.
- Démarrage validé Un ensemble de vérifications cryptographiques du logiciel système est effectué avant l'exécution pour s'assurer que le téléphone est en bon état, du bootloader au système d'exploitation.
- Sécurité isolée par matériel Nouvelle couche d'abstraction matérielle (HAL) utilisée par l'API Fingerprint, l'écran de verrouillage, le chiffrement de l'appareil et les certificats client pour protéger les clés contre la compromission du noyau et/ou les attaques physiques locales
- Empreintes digitales Les appareils peuvent désormais être déverrouillés d'une simple pression du doigt. Les développeurs peuvent également utiliser les nouvelles API pour verrouiller et déverrouiller des clés de chiffrement à l'aide d'empreintes digitales.
- Adoption de la carte SD Les supports amovibles peuvent être adoptés sur un appareil et augmenter l'espace de stockage disponible pour les données locales de l'application, les photos, les vidéos, etc., tout en étant protégés par le chiffrement au niveau des blocs.
- Trafic en texte clair Les développeurs peuvent utiliser un nouveau mode strict pour s'assurer que leur application n'utilise pas de texte clair.
- Renforcement du système. Durcissement du système via des règles appliquées par SELinux. Cela offre une meilleure isolation entre les utilisateurs, un filtrage IOCTL, une réduction de la menace des services exposés, un renforcement supplémentaire des domaines SELinux et un accès /proc extrêmement limité.
- Contrôle des accès USB:les utilisateurs doivent confirmer pour autoriser l'accès USB aux fichiers, au stockage ou à d'autres fonctionnalités du téléphone. La valeur par défaut est désormais Charger uniquement, avec un accès au stockage nécessitant l'approbation explicite de l'utilisateur.
Android 5
5,0
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。以下是 Android 5.0 中提供的一些主要安全增强功能:
- 默认加密。在以开箱即用的方式搭载 L 的设备上,会默认启用全盘加密功能,以便更好地保护丢失设备或被盗设备上的数据。对于更新到 L 的设备,可以在设置 > 安全性部分进行加密。
- 经过改进的全盘加密功能。使用
scrypt
保护用户密码免遭暴力破解攻击;在可能的情况下,该密钥会绑定到硬件密钥库,以防范来自设备外的攻击。 和以往一样,Android 屏幕锁定密钥和设备加密密钥不会被发送到设备以外,也不会提供给任何应用。 - 通过 SELinux 得到增强的 Android 沙盒。对于所有域,Android 现在都要求 SELinux 处于强制模式。SELinux 是 Linux 内核中的强制访问控制 (MAC) 系统,用于增强现有的自主访问控制 (DAC) 安全模型。这个新的安全层为防范潜在的安全漏洞提供了额外的保护屏障。
- Smart Lock。Android 现在包含一些 Trustlet,它们可以提供更灵活的设备解锁方式。 例如,Trustlet 可让设备在靠近其他可信设备时自动解锁(通过 NFC、蓝牙),或让设备在用户拥有可信面孔时自动解锁。
- 面向手机和平板电脑的多用户功能、受限个人资料和访客模式。Android 现在为手机提供了多用户功能,并包含一个访客模式。利用访客模式,您可以让访客轻松地临时使用您的设备,而不向他们授予对您的数据和应用的访问权限。
- 不使用 OTA 的 WebView 更新方式。现在可以独立于框架对 WebView 进行更新,而且无需采用系统 OTA 方式。 这有助于更快速地应对 WebView 中的潜在安全问题。
- 经过更新的 HTTPS 和 TLS/SSL 加密功能。现在启用了 TLSv1.2 和 TLSv1.1,首选是正向加密,启用了 AES-GCM,停用了弱加密套件(MD5、3DES 和导出密码套件)。如需了解详情,请访问 https://developer.android.com/reference/javax/net/ssl/SSLSocket.html。
- 移除了非 PIE 链接器支持。Android 现在要求所有动态链接的可执行文件都要支持 PIE(位置无关可执行文件)。这有助于增强 Android 的地址空间布局随机化 (ASLR) 实现。
- FORTIFY_SOURCE 改进。以下 libc 函数现在实现了 FORTIFY_SOURCE 保护功能:
stpcpy()
、stpncpy()
、read()
、recvfrom()
、FD_CLR()
、FD_SET()
和FD_ISSET()
。这有助于防范涉及这些函数的内存损坏漏洞。 - 安全修复程序。Android 5.0 中还包含针对 Android 特有漏洞的修复程序。有关这些漏洞的信息已提供给“开放手机联盟”(Open Handset Alliance) 成员,并且 Android 开放源代码项目中提供了相应的修复程序。为了提高安全性,部分搭载更低版本 Android 系统的设备可能也会包含这些修复程序。
Android 4 ou version antérieure
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。以下是 Android 4.4 中提供的一些安全增强功能:
- 通过 SELinux 得到增强的 Android 沙盒。 Android 现在以强制模式使用 SELinux。SELinux 是 Linux 内核中的强制访问控制 (MAC) 系统,用于增强基于自主访问控制 (DAC) 的现有安全模型。 这为防范潜在的安全漏洞提供了额外的保护屏障。
- 按用户应用 VPN。 在多用户设备上,现在按用户应用 VPN。 这样一来,用户就可以通过一个 VPN 路由所有网络流量,而不会影响使用同一设备的其他用户。
- AndroidKeyStore 中的 ECDSA 提供程序支持。 Android 现在有一个允许使用 ECDSA 和 DSA 算法的密钥库提供程序。
- 设备监测警告。 如果有任何可能允许监测加密网络流量的证书添加到设备证书库中,Android 都会向用户发出警告。
- FORTIFY_SOURCE。 Android 现在支持 FORTIFY_SOURCE 第 2 级,并且所有代码在编译时都会受到这些保护。FORTIFY_SOURCE 已得到增强,能够与 Clang 配合使用。
- 证书锁定。 Android 4.4 能够检测安全的 SSL/TLS 通信中是否使用了欺诈性 Google 证书,并且能够阻止这种行为。
- 安全修复程序。 Android 4.4 中还包含针对 Android 特有漏洞的修复程序。 有关这些漏洞的信息已提供给“开放手机联盟”(Open Handset Alliance) 成员,并且 Android 开源项目中提供了相应的修复程序。为了提高安全性,搭载更低版本 Android 的某些设备可能也会包含这些修复程序。
Chaque version d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des améliorations de sécurité disponibles dans Android 4.3:
- Bac à sable Android renforcé avec SELinux Cette version renforce le bac à sable Android à l'aide du système de contrôle d'accès obligatoire (MAC) SELinux dans le noyau Linux. Le renforcement de SELinux est invisible pour les utilisateurs et les développeurs, et ajoute de la robustesse au modèle de sécurité Android existant tout en conservant la compatibilité avec les applications existantes. Pour assurer la compatibilité, cette version permet d'utiliser SELinux en mode permissif. Ce mode consigne tous les cas de non-respect des règles, mais ne casse pas les applications ni n'affecte le comportement du système.
- Aucun programme
setuid
ousetgid
. Ajout de la compatibilité avec les fonctionnalités de système de fichiers aux fichiers système Android et suppression de tous les programmessetuid
ousetgid
. Cela réduit la surface d'attaque de la racine et la probabilité de failles de sécurité potentielles. - Authentification ADB À partir d'Android 4.2.2, les connexions à ADB sont authentifiées à l'aide d'une paire de clés RSA. Cela empêche l'utilisation non autorisée d'ADB lorsque le pirate informatique dispose d'un accès physique à un appareil.
- Limitez Setuid dans les applications Android.
La partition
/system
est désormais montée en mode nosuid pour les processus créés par zygote, ce qui empêche les applications Android d'exécuter des programmessetuid
. Cela réduit la surface d'attaque de la racine et la probabilité de failles de sécurité potentielles. - Limites de capacité.
Android zygote et ADB utilisent désormais
prctl(PR_CAPBSET_DROP)
pour supprimer les fonctionnalités inutiles avant d'exécuter les applications. Cela empêche les applications Android et les applications lancées à partir de la coque d'acquérir des fonctionnalités privilégiées. - Fournisseur AndroidKeyStore Android dispose désormais d'un fournisseur de keystore qui permet aux applications de créer des clés d'utilisation exclusives. Cela fournit aux applications une API permettant de créer ou de stocker des clés privées qui ne peuvent pas être utilisées par d'autres applications.
- KeyChain
isBoundKeyAlgorithm
. L'API Keychain fournit désormais une méthode (isBoundKeyType
) qui permet aux applications de confirmer que les clés à l'échelle du système sont liées à une racine de confiance matérielle pour l'appareil. Cela permet de créer ou de stocker des clés privées qui ne peuvent pas être exportées depuis l'appareil, même en cas de compromission du root. NO_NEW_PRIVS
: le zygote Android utilise désormaisprctl(PR_SET_NO_NEW_PRIVS)
pour bloquer l'ajout de nouveaux droits d'accès avant l'exécution du code de l'application. Cela empêche les applications Android d'effectuer des opérations pouvant accroître les droits d'accès via execve. (cela nécessite la version 3.5 ou ultérieure du noyau Linux).- Améliorations apportées à
FORTIFY_SOURCE
. Activation deFORTIFY_SOURCE
sur Android x86 et MIPS, et renforcement des appelsstrchr()
,strrchr()
,strlen()
etumask()
. Cela peut détecter des failles potentielles de corruption de mémoire ou des constantes de chaîne non terminées. - Protections contre les transferts Activation des relocations en lecture seule (relro) pour les exécutables liés de manière statique et suppression de toutes les relocations de texte dans le code Android. Cela offre une défense en profondeur contre les failles de corruption de mémoire potentielles.
- Amélioration d'EntropyMixer. EntropyMixer écrit désormais l'entropie au moment de l'arrêt ou du redémarrage, en plus du mélange périodique. Cela permet de conserver toute l'entropie générée lorsque les appareils sont allumés, et est particulièrement utile pour les appareils qui sont redémarrés immédiatement après le provisionnement.
- Correctifs de sécurité Android 4.3 inclut également des correctifs pour les failles spécifiques à Android. Des informations sur ces failles ont été fournies aux membres de l'Open Handset Alliance, et des correctifs sont disponibles dans le projet Android Open Source. Pour améliorer la sécurité, certains appareils équipés de versions antérieures d'Android peuvent également inclure ces correctifs.
Android fournit un modèle de sécurité multicouche décrit dans la présentation de la sécurité Android. Chaque mise à jour d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des améliorations de sécurité introduites dans Android 4.2:
- Validation des applications:les utilisateurs peuvent choisir d'activer la validation des applications et de faire passer les applications en vérification par un outil de validation avant leur installation. La validation des applications peut alerter l'utilisateur s'il tente d'installer une application potentiellement dangereuse. Si une application est particulièrement dangereuse, elle peut bloquer l'installation.
- Contrôle accru des SMS premium:Android envoie une notification si une application tente d'envoyer un SMS à un numéro court qui utilise des services premium pouvant entraîner des frais supplémentaires. L'utilisateur peut choisir d'autoriser l'application à envoyer le message ou de le bloquer.
- VPN permanent:le VPN peut être configuré de sorte que les applications n'aient pas accès au réseau tant qu'une connexion VPN n'est pas établie. Cela empêche les applications d'envoyer des données sur d'autres réseaux.
- Épinglage de certificat:les bibliothèques principales Android prennent désormais en charge l'épinglage de certificat. Les domaines épinglés reçoivent une erreur de validation de certificat si le certificat ne s'enchaîne pas à un ensemble de certificats attendus. Cela permet de se protéger d'un éventuel piratage des autorités de certification.
- Affichage amélioré des autorisations Android:les autorisations sont organisées en groupes plus faciles à comprendre pour les utilisateurs. Lors de l'examen des autorisations, l'utilisateur peut cliquer sur l'autorisation pour obtenir des informations plus détaillées à son sujet.
- durcissement installd:le daemon
installd
ne s'exécute pas en tant qu'utilisateur racine, ce qui réduit la surface d'attaque potentielle pour l'escalade des privilèges racine. - Durcissement des scripts d'initialisation:les scripts d'initialisation appliquent désormais la sémantique
O_NOFOLLOW
pour éviter les attaques liées aux liens symboliques. FORTIFY_SOURCE
:Android implémente désormaisFORTIFY_SOURCE
. Les bibliothèques système et les applications l'utilisent pour éviter la corruption de la mémoire.- Configuration par défaut de ContentProvider:pour chaque ContentProvider, la valeur
export
est définie surfalse
par défaut pour les applications qui ciblent le niveau d'API 17, ce qui réduit la surface d'attaque par défaut des applications. - Cryptographie:modification des implémentations par défaut de SecureRandom et Cipher.RSA pour utiliser OpenSSL. Ajout de la compatibilité avec les sockets SSL pour TLSv1.1 et TLSv1.2 à l'aide d'OpenSSL 1.0.1
- Corrections de sécurité:les bibliothèques Open Source mises à niveau avec des correctifs de sécurité incluent WebKit, libpng, OpenSSL et LibXML. Android 4.2 inclut également des correctifs pour les failles spécifiques à Android. Des informations sur ces failles ont été fournies aux membres de l'Open Handset Alliance, et des correctifs sont disponibles dans le projet Open Source Android. Pour améliorer la sécurité, certains appareils équipés de versions antérieures d'Android peuvent également inclure ces correctifs.
Android fournit un modèle de sécurité multicouche décrit dans la présentation de la sécurité Android. Chaque mise à jour d'Android comprend des dizaines d'améliorations de sécurité pour protéger les utilisateurs. Voici quelques-unes des améliorations de sécurité introduites dans les versions Android 1.5 à 4.1:
- Android 1.5
- ProPolice pour éviter les dépassements de tampon de pile (-fstack-protector)
- safe_iop pour réduire les débordements d'entiers
- Extensions de dlmalloc OpenBSD pour éviter les failles de double free() et les attaques de consolidation de blocs. Les attaques de consolidation de blocs sont un moyen courant d'exploiter la corruption de tas.
- calloc OpenBSD pour éviter les débordements d'entiers lors de l'allocation de mémoire
- Android 2.3
- Protection contre les failles de chaîne de format (-Wformat-security -Werror=format-security)
- NX (Never eXecute) matériel pour empêcher l'exécution de code sur la pile et la mémoire heap
- Linux mmap_min_addr pour atténuer l'escalade des droits d'accès en cas de déréférencement de pointeur nul (encore amélioré dans Android 4.1)
- Android 4.0
- La randomisation de la disposition de l'espace d'adressage (ASLR, Address Space Layout Randomization) pour randomiser les emplacements clés en mémoire
- Android 4.1
- Compatibilité avec les fichiers exécutables indépendants de la position (PIE)
- Déplacements en lecture seule / liaison immédiate (-Wl,-z,relro -Wl,-z,now)
- dmesg_restrict activé (éviter les fuites d'adresses de noyau)
- kptr_restrict activé (pour éviter les fuites d'adresses de kernel)