Android mejora continuamente sus funciones y ofertas de seguridad. Consulta las listas de mejoras por versión en el panel de navegación izquierdo.
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
每个 Android 版本中都包含数十种用于保护用户的安全增强功能。以下是 Android 13 中提供的一些主要安全增强功能:
- Android 13 添加了对多文档呈现的支持。 通过这个新的 Presentation Session 接口,应用可以执行多文档呈现,而现有 API 无法做到这一点。如需了解详情,请参阅身份凭据
- 在 Android 13 中,当且仅当源自外部应用的 intent 与其声明的 intent 过滤器元素匹配时,这些 intent 才会传送到导出的组件。
- Open Mobile API (OMAPI) 是一种标准 API,用于与设备的安全元件进行通信。在 Android 13 之前,只有应用和框架模块可以访问此接口。通过将其转换为供应商稳定版接口,HAL 模块还能够通过 OMAPI 服务与安全元件进行通信。 如需了解详情,请参阅 OMAPI 供应商稳定版接口。
- 从 Android 13-QPR 开始,共享 UID 被废弃。 使用 Android 13 或更高版本的用户应在其清单中添加 `android:sharedUserMaxSdkVersion="32"` 行。此条目可防止新用户获取共享 UID。如需详细了解 UID,请参阅应用签名。
- Android 13 添加了对密钥库对称加密基元的支持,例如支持 AES(高级加密标准)、HMAC(密钥哈希消息认证码)以及非对称加密算法(包括椭圆曲线加密、RSA2048、RSA4096 和曲线 25519 加密)
- Android 13(API 级别 33)及更高版本支持用于从应用发送非豁免通知的运行时权限。这可让用户控制他们会看到哪些权限通知。
- 针对请求访问所有设备日志的应用,添加了在每次使用时显示提示的功能,以便用户允许或拒绝授予访问权限。
- 推出了 Android 虚拟化框架 (AVF),它使用标准化 API 将不同的 Hypervisor 整合到一个框架下。 它提供安全、私密的执行环境,以便执行通过 Hypervisor 隔离的工作负载。
- 引入了 APK 签名方案 v3.1 所有使用 apksigner 的新密钥轮替都将默认使用 v3.1 签名方案,以便将 Android 13 及更高版本作为轮替目标。
Android 12
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Estas son algunas de las principales mejoras de seguridad disponibles en Android 12:
- Android 12 introduce la API de BiometricManager.Strings, que proporciona cadenas localizadas para las apps que usan BiometricPrompt para la autenticación. Estas cadenas están diseñadas para tener en cuenta el dispositivo y proporcionar más especificidad sobre qué tipos de autenticación se pueden usar. Android 12 también incluye compatibilidad con sensores de huellas dactilares debajo de la pantalla.
- Se agregó compatibilidad con sensores de huellas dactilares debajo de la pantalla
- Introducción al lenguaje de definición de la interfaz de Android de huella digital (AIDL)
- Compatibilidad con el nuevo AIDL de Face
- Introducción de Rust como lenguaje para el desarrollo de la plataforma
- Se agregó la opción para que los usuarios otorguen acceso solo a su ubicación aproximada.
- Se agregaron indicadores de privacidad en la barra de estado cuando una app usa la cámara o el micrófono.
- Private Compute Core (PCC) de Android
- Se agregó una opción para inhabilitar la compatibilidad con 2G
Android 11
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Para ver una lista de algunas de las principales mejoras de seguridad disponibles en Android 11, consulta las Notas de la versión de Android.
Android 10
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Android 10 incluye varias mejoras de seguridad y privacidad. Consulta las notas de la versión de Android 10 para obtener una lista completa de los cambios en Android 10.
Seguridad
BoundsSanitizer
Android 10 implementa BoundsSanitizer (BoundSan) en Bluetooth y códecs. BoundSan usa la limpieza de límites de UBSan. Esta mitigación está habilitada a nivel de cada módulo. Ayuda a mantener seguros los componentes importantes de Android y no debe inhabilitarse. BoundSan está habilitado en los siguientes códecs:
libFLAClibavcdeclibavcenclibhevcdeclibmpeg2libopuslibvpxlibspeexresamplerlibvorbisideclibaaclibxaac
Memoria de solo ejecución
De forma predeterminada, las secciones de código ejecutable de los objetos binarios del sistema AArch64 están marcadas como de solo ejecución (no legibles) para endurecer la mitigación contra ataques de reutilización de código just-in-time. El código que combina los datos y el código, y el código que inspecciona deliberadamente esas secciones (sin reasignar primero los segmentos de la memoria como legibles) ya no funciona. Las apps con un SDK de destino de Android 10 (nivel de API 29 o versiones posteriores) se ven afectadas si la app intenta leer secciones de código de bibliotecas del sistema habilitadas con memoria de solo ejecución (XOM) en la memoria sin primero marcar la sección como legible.
Acceso ampliado
Los agentes de confianza, el mecanismo subyacente que usan los mecanismos de autenticación terciarios como Smart Lock, solo pueden ampliar el desbloqueo en Android 10. Los agentes de confianza ya no pueden desbloquear un dispositivo bloqueado y solo pueden mantenerlo desbloqueado por un máximo de cuatro horas.
Autenticación facial
La autenticación facial permite a los usuarios desbloquear el dispositivo con solo mirar la parte frontal. Android 10 agrega compatibilidad para una pila nueva de autenticación facial que puede procesar marcos de cámara de forma segura, lo que preserva la seguridad y privacidad durante la autenticación facial en hardware compatible. Android 10 también facilita que las implementaciones que cumplen con la seguridad permitan la integración de apps para transacciones de banca en línea, por ejemplo, y otros servicios.
Limpieza de desbordamiento de enteros
Android 10 habilita la limpieza de desbordamiento de enteros (IntSan) en códecs de software. Asegúrate de que el rendimiento de reproducción sea aceptable para cualquier códec que no sea compatible con el hardware del dispositivo. IntSan está habilitada en los siguientes códecs:
libFLAClibavcdeclibavcenclibhevcdeclibmpeg2libopuslibvpxlibspeexresamplerlibvorbisidec
Componentes modulares del sistema
Android 10 modulariza algunos componentes del sistema Android y les permite actualizarse fuera del ciclo normal de lanzamientos de Android. Algunos módulos incluyen lo siguiente:
- Android Runtime
- Conscrypt
- Resolución de DNS
- DocumentsUI
- ExtServices
- Contenido multimedia
- ModuleMetadata
- Redes
- PermissionController
- Datos de la zona horaria
OEMCrypto
Android 10 usa la versión 15 de la API de OEMCrypto.
Scudo
Scudo es un asignador de memoria dinámico en modo de usuario diseñado para ser más resistente contra las vulnerabilidades relacionadas con pilas. Proporciona las primitivas de asignación y desasignación estándar de C, así como las primitivas de C++.
ShadowCallStack
ShadowCallStack
(SCS) es un modo de instrumentación de LLVM que protege contra las reescrituras de la dirección de devolución (como los desbordamientos del búfer de pila) guardando la dirección de devolución de una función en una instancia de ShadowCallStack asignada por separado en el prologo de la función de las funciones no hoja y cargando la dirección de devolución desde la instancia de ShadowCallStack en el epílogo de la función.
WPA3 y Wi-Fi Enhanced Open
Android 10 agrega compatibilidad con los estándares de seguridad de Wi-Fi Protected Access 3 (WPA3) y Wi-Fi Enhanced Open para proporcionar una mayor privacidad y solidez frente a ataques conocidos.
Privacidad
Acceso de apps cuando se orientan a Android 9 o versiones anteriores
Si tu app se ejecuta en Android 10 o versiones posteriores, pero está orientada a Android 9 (nivel de API 28) o versiones anteriores, la plataforma se comportará de la siguiente manera:
- Si tu app declara un elemento
<uses-permission>paraACCESS_FINE_LOCATIONoACCESS_COARSE_LOCATION, el sistema agrega automáticamente un elemento<uses-permission>paraACCESS_BACKGROUND_LOCATIONdurante la instalación. - Si tu app solicita
ACCESS_FINE_LOCATIONoACCESS_COARSE_LOCATION, el sistema automáticamente agregaACCESS_BACKGROUND_LOCATIONa la solicitud.
Restricciones de actividad en segundo plano
A partir de Android 10, el sistema impone restricciones sobre el inicio de actividades en segundo plano. Este cambio de comportamiento ayuda a minimizar las interrupciones para el usuario y a darle más control de lo que aparece en la pantalla. Siempre que tu app inicie actividades como resultado directo de la interacción del usuario, es muy probable que no se vea afectada por estas restricciones.
Para obtener más información sobre la alternativa recomendada para iniciar actividades en
segundo plano, consulta la guía sobre cómo alertar a los usuarios de los eventos sujetos a horarios específicos en tu app.
Metadatos de la cámara
Android 10 modifica la cantidad de información que el método getCameraCharacteristics() muestra de forma predeterminada. Tu app debe tener el permiso CAMERA para poder acceder a los metadatos potencialmente específicos de un dispositivo incluidos en el valor que muestra ese método.
Para obtener más información sobre estos cambios, consulta la sección sobre los campos de la cámara que requieren permiso.
Datos del portapapeles
A menos que tu app sea el Editor de método de entrada (IME) predeterminado o esté enfocada, no podrá acceder a los datos del portapapeles en Android 10 o versiones posteriores.
Ubicación del dispositivo
Para admitir el control adicional que tienen los usuarios sobre el acceso de la app a la información de ubicación, en Android 10 se introduce el permiso ACCESS_BACKGROUND_LOCATION.
A diferencia de los permisos ACCESS_FINE_LOCATION
y ACCESS_COARSE_LOCATION, el permiso ACCESS_BACKGROUND_LOCATION solo afecta
el acceso de una app a la ubicación cuando se ejecuta en segundo plano. Se considera que una app accede a la ubicación en segundo plano siempre y cuando no se cumpla alguna de las siguientes condiciones:
- Se muestra una actividad que pertenece a otra app.
- La app ejecuta un servicio en primer plano que declaró un tipo de servicio en primer plano de
location.
Para declarar el tipo de servicio en primer plano para un servicio de tu app, establecetargetSdkVersionocompileSdkVersionde tu app en29o una versión posterior. Obtén más información sobre cómo los servicios en primer plano pueden continuar acciones iniciadas por el usuario que requieren acceso a la ubicación.
Almacenamiento externo
De forma predeterminada, a las apps que se orientan a Android 10 y versiones posteriores se les otorga acceso específico al almacenamiento externo o almacenamiento específico. Estas apps pueden ver los siguientes tipos de archivos dentro de un dispositivo de almacenamiento externo sin tener que solicitar permisos al usuario relacionados con el almacenamiento:
- Archivos en el directorio específico de la app, a los que se accede mediante
getExternalFilesDir(). - Fotos, videos y clips de audio que la app creó desde el almacén de contenido multimedia
Para obtener más información sobre el almacenamiento específico, además de cómo compartir, acceder y modificar archivos que se guardan en dispositivos de almacenamiento externo, consulta las guías sobre cómo administrar archivos en el almacenamiento externo y cómo acceder a archivos multimedia y modificarlos.
Aleatorización de direcciones MAC
En los dispositivos que ejecutan Android 10 o versiones posteriores, el sistema transmite direcciones MAC aleatorias de forma predeterminada.
Si tu app administra un caso de uso empresarial, la
plataforma proporciona APIs para varias operaciones relacionadas con direcciones MAC:
- Obtén direcciones MAC aleatorias: Las apps de propietarios de dispositivos y perfiles pueden recuperar las direcciones MAC aleatorias asignadas a una red específica mediante una llamada a
getRandomizedMacAddress(). - Obtén direcciones MAC de fábrica reales: Las apps para propietarios de dispositivos pueden recuperar la dirección MAC real del hardware del dispositivo mediante una llamada a
getWifiMacAddress(). Este método es útil para realizar un seguimiento de varios dispositivos.
Identificadores de dispositivo que no se pueden restablecer
A partir de Android 10, las apps deben tener el permiso de firma READ_PRIVILEGED_PHONE_STATE para acceder a los identificadores que no se pueden restablecer del dispositivo, incluido el IMEI y el número de serie.
BuildTelephonyManager
Si tu app no tiene el permiso y solicitas información sobre los identificadores que no se pueden restablecer, la respuesta de la plataforma variará en función de la versión del SDK de destino:
- Si tu app se orienta a Android 10 o versiones posteriores, se genera una
SecurityException. - Si tu app se orienta a Android 9 (nivel de API 28) o versiones anteriores, el método muestra
nullo datos del marcador de posición si la app tiene el permisoREAD_PHONE_STATE. De lo contrario, se produce unSecurityException.
Reconocimiento de actividad física
Android 10 introduce el permiso de tiempo de ejecución android.permission.ACTIVITY_RECOGNITION para apps que necesitan detectar el recuento de pasos del usuario o clasificar su actividad física, como cuando camina, anda en bicicleta o está en un vehículo. Está diseñado para darles a los usuarios mayor visibilidad sobre cómo se usan los datos del sensor del dispositivo en Configuración.
Algunas bibliotecas dentro de los servicios de Google Play, como la API de Activity Recognition y la API de Google Fit, no proporcionan resultados, a menos que el usuario haya otorgado este permiso a tu app.
Los únicos sensores incorporados en el dispositivo que requieren que declares este permiso son el contador de pasos y el detector de pasos.
Si tu app se orienta a Android 9 (nivel de API 28) o versiones anteriores, el sistema otorga automáticamente el permiso android.permission.ACTIVITY_RECOGNITION a tu app, según sea necesario, si esta cumple con cada una de las siguientes condiciones:
- El archivo de manifiesto incluye el permiso
com.google.android.gms.permission.ACTIVITY_RECOGNITION. - El archivo de manifiesto no incluye el permiso
android.permission.ACTIVITY_RECOGNITION.
Si el sistema otorga automáticamente el permiso android.permission.ACTIVITY_RECOGNITION, tu app retendrá el permiso después de que la actualices para que se oriente a Android 10. Sin embargo, el usuario puede revocar este permiso en cualquier momento desde la configuración del sistema.
Restricciones del sistema de archivos /proc/net
En dispositivos que ejecutan Android 10 o versiones posteriores, las apps no pueden acceder a /proc/net, que incluye información sobre el estado de red de un dispositivo. Las apps que necesitan acceder a este tipo de información, como las VPN, deben usar la clase NetworkStatsManager o ConnectivityManager.
Se quitaron los grupos de permisos de la IU
Desde Android 10, las apps ya no pueden ver cómo se agrupan los permisos en la IU.
Eliminación de la afinidad de contactos
A partir de Android 10, la plataforma no realiza el seguimiento de la información de la afinidad de contactos. Como resultado, si tu app realiza una búsqueda en los contactos del usuario, los resultados no se ordenan por frecuencia de interacción.
La guía sobre ContactsProvider contiene un aviso que describe los campos y métodos específicos que dejarán de estar disponibles en todos los dispositivos a partir de Android 10.
Acceso restringido a contenido de la pantalla
Para proteger el contenido de la pantalla de los usuarios, Android 10 cambia el alcance que tienen los permisos READ_FRAME_BUFFER, CAPTURE_VIDEO_OUTPUT y CAPTURE_SECURE_VIDEO_OUTPUT para evitar el acceso silencioso al contenido de la pantalla del dispositivo. A partir de Android 10, solo se puede acceder a estos permisos mediante una firma.
Las apps que necesiten acceder al contenido de la pantalla del dispositivo deberán usar la
API de MediaProjection, que muestra un mensaje en el que se le pide al usuario que otorgue su consentimiento.
Número de serie del dispositivo USB
Si tu app está orientada a Android 10 o versiones posteriores, no podrá leer el número de serie hasta que el usuario otorgue el permiso de app al accesorio o dispositivo USB.
Para obtener más información sobre cómo trabajar con dispositivos USB, consulta la guía sobre cómo configurar hosts USB.
Wi-Fi
Las apps que se orientan a Android 10 o versiones posteriores no pueden habilitar ni inhabilitar la red Wi-Fi. El método WifiManager.setWifiEnabled() siempre muestra false.
Si necesitas solicitarles a los usuarios que habiliten o inhabiliten la red Wi-Fi, usa un panel de configuración.
Restricciones sobre el acceso directo a redes Wi-Fi configuradas
Para proteger la privacidad del usuario, la configuración manual de la lista de redes Wi-Fi se restringe a apps del sistema y controladores de políticas de dispositivos (DPC). Un DPC específico puede ser el propietario del dispositivo o el del perfil.
Si tu app se orienta a Android 10 o versiones posteriores, y no es una app del sistema o un DPC, entonces los siguientes métodos no mostrarán datos útiles:
- El método
getConfiguredNetworks()siempre muestra una lista vacía. - Todos los métodos de la operación de red que muestran un valor entero (
addNetwork()yupdateNetwork()) mostrarán siempre -1. - Cada operación de red que muestra un valor booleano (
removeNetwork(),reassociate(),enableNetwork(),disableNetwork(),reconnect()ydisconnect()) siempre muestrafalse.
Android 9
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Para obtener una lista de algunas de las principales mejoras de seguridad disponibles en Android 9, consulta las Notas de la versión de Android.
Android 8
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Estas son algunas de las principales mejoras de seguridad disponibles en Android 8.0:
- Encriptación. Se agregó compatibilidad para desalojar la clave en el perfil de trabajo.
- Inicio verificado. Se agregó el inicio verificado de Android (AVB). Base de código de inicio verificado que admite la protección de reversión para usar en los cargadores de arranque agregados a AOSP. Se recomienda la compatibilidad con el bootloader para la protección contra reversiones del HLOS. Se recomienda que los cargadores de arranque solo se puedan desbloquear si el usuario interactúa físicamente con el dispositivo.
- Pantalla de bloqueo. Se agregó compatibilidad con el uso de hardware resistente a las manipulaciones para verificar la credencial de la pantalla de bloqueo.
- KeyStore. Se requiere certificación de claves para todos los dispositivos que se envían con Android 8.0 y versiones posteriores. Se agregó compatibilidad con la certificación de ID para mejorar la inscripción automática.
- Zona de pruebas Muchos componentes están más ajustados en la zona de pruebas con la interfaz estándar de Project Treble entre el framework y los componentes específicos del dispositivo. Se aplicó el filtrado de seccomp a todas las apps no confiables para reducir la superficie de ataque del kernel. WebView ahora se ejecuta en un proceso aislado con acceso muy limitado al resto del sistema.
- Endurecimiento del kernel. Se implementó la copia de usuario endurecida, la emulación de PAN, el modo de solo lectura después de la inicialización y KASLR.
- Endurecimiento del espacio de usuario. Se implementó la CFI para la pila de medios. Las superposiciones de apps ya no pueden cubrir ventanas críticas del sistema, y los usuarios tienen una forma de descartarlas.
- Actualización del SO por transmisión. Se habilitaron las actualizaciones en dispositivos que tienen poco espacio en el disco.
- Instalar apps desconocidas. Los usuarios deben otorgar permiso para instalar apps de una fuente que no sea una tienda de aplicaciones propia.
- Privacidad. El ID de Android (SSAID) tiene un valor diferente para cada app y cada usuario en el dispositivo. En el caso de las apps de navegador web, el ID de cliente de Widevine muestra un valor diferente para cada nombre de paquete de la app y origen web.
net.hostnameahora está vacío y el cliente DHCP ya no envía un nombre de host.android.os.Build.SERIALse reemplazó por la API deBuild.SERIAL, que está protegida por un permiso controlado por el usuario. Se mejoró la aleatorización de direcciones MAC en algunos conjuntos de chips.
Android 7
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。以下是 Android 7.0 中提供的一些主要安全增强功能:
- 文件级加密:在文件级进行加密,而不是将整个存储区域作为单个单元进行加密。这种加密方式可以更好地隔离和保护设备上的不同用户和资料(例如个人资料和工作资料)。
- 直接启动:通过文件级加密实现,允许特定应用(例如,闹钟和无障碍功能)在设备已开机但未解锁的情况下运行。
- 验证启动:现在,验证启动会被严格强制执行,从而使遭到入侵的设备无法启动;验证启动支持纠错功能,有助于更可靠地防范非恶意数据损坏。
- SELinux。更新后的 SELinux 配置和更高的 Seccomp 覆盖率有助于进一步锁定应用沙盒并减小受攻击面。
- 库加载顺序随机化和改进的 ASLR。 增大随机性降低了某些代码重用攻击的有效性。
- 内核加固:通过将内核内存的各个分区标记为只读,限制内核对用户空间地址的访问,并进一步减小现有的受攻击面,为更高版本的内核添加额外的内存保护。
- APK 签名方案 v2:引入了一种全文件签名方案,该方案有助于加快验证速度并增强完整性保证。
- 可信 CA 存储区。为了使应用更容易控制对其安全网络流量的访问,对于 API 级别为 24 及以上的应用,由用户安装的证书颁发机构以及通过 Device Admin API 安装的证书颁发机构在默认情况下不再受信任。此外,所有新的 Android 设备必须搭载相同的可信 CA 存储区。
- 网络安全配置。通过声明式配置文件来配置网络安全设置和传输层安全协议 (TLS)。
Android 6
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Estas son algunas de las principales mejoras de seguridad disponibles en Android 6.0:
- Permisos de tiempo de ejecución. Las apps solicitan permisos durante el tiempo de ejecución en lugar de que se les otorguen en el momento de la instalación. Los usuarios pueden activar o desactivar los permisos de las apps para M y anteriores.
- Inicio verificado. Antes de la ejecución, se realiza un conjunto de verificaciones criptográficas del software del sistema para garantizar que el teléfono esté en buen estado desde el bootloader hasta el sistema operativo.
- Seguridad aislada por hardware. Nueva capa de abstracción de hardware (HAL) que usan la API de huellas dactilares, la pantalla de bloqueo, la encriptación del dispositivo y los certificados de cliente para proteger las claves contra ataques físicos locales o de vulneración del kernel
- Huellas dactilares: Ahora los dispositivos se pueden desbloquear con un solo toque. Los desarrolladores también pueden aprovechar las nuevas APIs para usar huellas dactilares para bloquear y desbloquear claves de encriptación.
- Adopción de tarjetas SD. El contenido multimedia extraíble se puede adoptar en un dispositivo y expandir el almacenamiento disponible para los datos locales de la app, las fotos, los videos, etcétera, pero aún puede estar protegido por encriptación a nivel de bloque.
- Tráfico de texto simple. Los desarrolladores pueden usar un nuevo StrictMode para asegurarse de que su app no use texto simple.
- Endurecimiento del sistema. Endurecimiento del sistema a través de políticas que aplica SELinux Esto ofrece un mejor aislamiento entre los usuarios, un filtrado de IOCTL, una reducción de la amenaza de los servicios expuestos, un mayor endurecimiento de los dominios de SELinux y un acceso extremadamente limitado a /proc.
- Control de acceso USB: Los usuarios deben confirmar que permiten el acceso USB a los archivos, el almacenamiento y otras funciones del teléfono. La opción predeterminada ahora es solo cobro, con acceso al almacenamiento que requiere la aprobación explícita del usuario.
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 y versiones anteriores
每个 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 的某些设备可能也会包含这些修复程序。
Todas las versiones de Android incluyen docenas de mejoras de seguridad para proteger a los usuarios. Las siguientes son algunas de las mejoras de seguridad disponibles en Android 4.3:
- La zona de pruebas de Android se reforzó con SELinux. Esta versión fortalece la zona de pruebas de Android con el sistema de control de acceso obligatorio (MAC) de SELinux en el kernel de Linux. El refuerzo de SELinux es invisible para los usuarios y desarrolladores, y agrega solidez al modelo de seguridad existente de Android, a la vez que mantiene la compatibilidad con las apps existentes. Para garantizar la compatibilidad continua, esta versión permite el uso de SELinux en un modo permisivo. Este modo registra cualquier incumplimiento de la política, pero no dañará las apps ni afectará el comportamiento del sistema.
- No hay programas
setuidnisetgid. Se agregó compatibilidad con las capacidades del sistema de archivos a los archivos del sistema de Android y se quitaron todos los programassetuidosetgid. De esta manera, se reduce la superficie de ataque de raíz y la probabilidad de posibles vulnerabilidades de seguridad. - Autenticación de ADB A partir de Android 4.2.2, las conexiones a ADB se autentican con un par de claves RSA. Esto evita el uso no autorizado de ADB cuando el atacante tiene acceso físico a un dispositivo.
- Restringe Setuid desde apps para Android.
La partición
/systemahora se activa en nosuid para procesos generados por Zygote, lo cual evita que las apps para Android ejecuten programassetuid. De esta manera, se reduce la superficie de ataque de raíz y la probabilidad de posibles vulnerabilidades de seguridad. - Limitación de capacidades.
El zygote de Android y ADB ahora usan
prctl(PR_CAPBSET_DROP)para descartar capacidades innecesarias antes de ejecutar apps. Esto evita que las apps para Android y las que se inician desde el shell adquieran capacidades privilegiadas. - Proveedor de AndroidKeyStore. Android ahora tiene un proveedor de almacén de claves que permite que las apps creen claves de uso exclusivo. Esto proporciona a las apps una API para crear o almacenar claves privadas que otras apps no pueden usar.
- Llavero
isBoundKeyAlgorithm. La API de Keychain ahora proporciona un método (isBoundKeyType) que permite a las apps confirmar que las claves de todo el sistema están vinculadas a una raíz de confianza de hardware para el dispositivo. Esto proporciona un lugar para crear o almacenar claves privadas que no se pueden exportar del dispositivo, incluso en el caso de un compromiso de raíz. NO_NEW_PRIVS: Ahora, el zygote de Android usaprctl(PR_SET_NO_NEW_PRIVS)para bloquear la adición de privilegios nuevos antes de ejecutar el código de la app. Esto evita que las apps para Android realicen operaciones que puedan elevar privilegios a través de execve. (Esto requiere la versión 3.5 o posterior del kernel de Linux).- Mejoras de
FORTIFY_SOURCE. Se habilitóFORTIFY_SOURCEen Android x86 y MIPS, y se fortalecieron las llamadasstrchr(),strrchr(),strlen()yumask(). Esto puede detectar posibles vulnerabilidades de corrupción de memoria o constantes de cadenas sin terminar. - Protección contra el traslado. Se habilitaron las reubicaciones de solo lectura (relro) para los ejecutables vinculados de forma estática y se quitaron todas las reubicaciones de texto en el código de Android. Esto proporciona una defensa en profundidad contra posibles vulnerabilidades de corrupción de la memoria.
- Se mejoró EntropyMixer. EntropyMixer ahora escribe entropía al finalizar o reiniciar, además de la mezcla periódica. Esto permite retener toda la entropía generada mientras los dispositivos están encendidos y es especialmente útil para los dispositivos que se reinician inmediatamente después del aprovisionamiento.
- Correcciones de seguridad Android 4.3 también incluye correcciones para vulnerabilidades específicas de Android. Los miembros de Open Handset Alliance recibieron información acerca de estas vulnerabilidades y las correcciones están disponibles en el Proyecto de código abierto de Android. Para mejorar la seguridad, es posible que algunos dispositivos con versiones anteriores de Android también incluyan estas correcciones.
Android proporciona un modelo de seguridad de varias capas que se describe en la Descripción general de seguridad de Android. Cada actualización de Android incluye docenas de mejoras de seguridad para proteger a los usuarios. A continuación, se muestran algunas de las mejoras de seguridad que se introdujeron en Android 4.2:
- Verificación de apps: Los usuarios pueden habilitar la función Verificar aplicaciones y hacer que las apps sean revisadas por un verificador de apps antes de la instalación. La verificación de aplicaciones puede alertar al usuario si intenta instalar una app que puede ser dañina. Si una app es particularmente mala, puede bloquear su instalación.
- Mayor control de los SMS premium: Android proporciona una notificación si una app intenta enviar SMS a un código corto que usa servicios premium que pueden generar cargos adicionales. El usuario puede elegir si desea permitir que la app envíe el mensaje o bloquearlo.
- VPN siempre activada: La VPN se puede configurar para que las apps no tengan acceso a la red hasta que se establezca una conexión VPN. De esta manera, se evita que las apps envíen datos a través de otras redes.
- Fijación de certificados: Las bibliotecas principales de Android ahora admiten la fijación de certificados. Los dominios fijados reciben un error de validación de certificado si el certificado no se encadena a un conjunto de certificados esperados. Esto brinda protección contra posibles compromisos de las autoridades certificadoras.
- Visualización mejorada de los permisos de Android: Los permisos se organizan en grupos que los usuarios pueden comprender más fácilmente. Durante la revisión de los permisos, el usuario puede hacer clic en el permiso para ver información más detallada.
- Endurecimiento de installd: El daemon
installdno se ejecuta como usuario raíz, lo que reduce la superficie de ataque potencial para la elevación de privilegios raíz. - Endurecimiento de la secuencia de comandos init: Ahora, las secuencias de comandos init aplican la semántica
O_NOFOLLOWpara evitar ataques relacionados con symlink. FORTIFY_SOURCE: Android ahora implementaFORTIFY_SOURCE. Esto lo utilizan las bibliotecas y apps del sistema para evitar daños en la memoria.- Configuración predeterminada de ContentProvider: Las apps que se orientan al nivel de API 17 tienen
exportestablecido enfalsede forma predeterminada para cada ContentProvider, lo que reduce la superficie de ataque predeterminada para las apps. - Criptografía: Se modificaron las implementaciones predeterminadas de SecureRandom y Cipher.RSA para usar OpenSSL. Se agregó compatibilidad con SSL Socket para TLSv1.1 y TLSv1.2 mediante OpenSSL 1.0.1.
- Correcciones de seguridad: Las bibliotecas de código abierto actualizadas con correcciones de seguridad incluyen WebKit, libpng, OpenSSL y LibXML. Android 4.2 también incluye correcciones para vulnerabilidades específicas de Android. Los miembros de Open Handset Alliance recibieron información acerca de estas vulnerabilidades y las correcciones están disponibles en el Proyecto de código abierto de Android. Para mejorar la seguridad, es posible que algunos dispositivos con versiones anteriores de Android también incluyan estas correcciones.
Android proporciona un modelo de seguridad de varias capas que se describe en la Descripción general de seguridad de Android. Cada actualización de Android incluye docenas de mejoras de seguridad para proteger a los usuarios. A continuación, se muestran algunas de las mejoras de seguridad que se introdujeron en las versiones de Android 1.5 a 4.1:
- Android 1.5
- ProPolice para evitar desbordamientos de búfer de pila (-fstack-protector)
- safe_iop para reducir los desbordamientos de números enteros
- Extensiones a dlmalloc de OpenBSD para evitar vulnerabilidades de doble free() y evitar ataques de consolidación de fragmentos. Los ataques de consolidación de fragmentos son una forma común de aprovechar la corrupción del montón.
- OpenBSD calloc para evitar desbordamientos de números enteros durante la asignación de memoria
- Android 2.3
- Protecciones contra vulnerabilidades de cadenas de formato (-Wformat-security -Werror=format-security)
- No eXecute (NX) basado en hardware para evitar la ejecución de código en la pila y el montón
- mmap_min_addr de Linux para mitigar la escalamiento de privilegios de eliminación de referencia de puntero nulo (se mejoró aún más en Android 4.1)
- Android 4.0
- Aleatorización del diseño del espacio de direcciones (ASLR) para aleatorizar las ubicaciones de claves en la memoria
- Android 4.1
- Compatibilidad con PIE (ejecutable independiente de la posición)
- Reubicaciones de solo lectura o vinculación inmediata (-Wl,-z,relro -Wl,-z,now)
- dmesg_restrict habilitado (evita la filtración de direcciones del kernel)
- kptr_restrict habilitado (evita la filtración de direcciones del kernel)