Android 不斷改進自家的安全性功能和產品,請參閱左側導覽面板中各版本的強化功能清單。
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
每个 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 的重要元件安全無虞,因此不應停用。我們在 下列轉碼器:
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 啟用 Integer Overflow 軟體轉碼器中的清理 (IntSan)。確保播放效能 可接受任何裝置硬體不支援的轉碼器。 已在下列轉碼器中啟用 IntSan:
libFLAC
libavcdec
libavcenc
libhevcdec
libmpeg2
libopus
libvpx
libspeexresampler
libvorbisidec
模組化系統元件
Android 10 將部分 Android 系統元件模組化,讓這些元件能夠在 Android 的正常發布週期外進行更新。部分模組包括:
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) 或更低的級別,平台會套用下列行為:
- 如果應用程式宣告
<uses-permission>
元素用於ACCESS_FINE_LOCATION
或ACCESS_COARSE_LOCATION
, 因為系統會自動新增<uses-permission>
元素ACCESS_BACKGROUND_LOCATION
。 - 如果您的應用程式要求
ACCESS_FINE_LOCATION
或ACCESS_COARSE_LOCATION
,系統會自動ACCESS_BACKGROUND_LOCATION
加進要求。
背景活動限制
自 Android 10 起,系統會設定限制
從背景啟動活動這項行為異動可盡量減少使用者的中斷情形,讓使用者更能掌控螢幕上顯示的內容。只要應用程式以直接結果啟動活動
表示您的應用程式很有可能不受這些限制影響。
如要進一步瞭解從以下位置開始活動的建議做法,請使用:
請參閱如何使用快訊
使用者在應用程式中進行限時敏感事件的使用者。
相機中繼資料
Android 10 改變了 getCameraCharacteristics()
的資訊廣泛
方法。具體來說,應用程式必須具備 CAMERA
權限,才能存取這個方法的傳回值中可能包含的裝置專屬中繼資料。
如要進一步瞭解這些更動,請參閱相機相關章節
欄位。
剪貼簿資料
除非您的應用程式為預設的輸入值 方法編輯器 (IME) 或目前含有焦點的應用程式,則您的應用程式無法 在 Android 10 以上版本中存取剪貼簿資料。
裝置定位功能
為支援使用者能控管應用程式存取權的其他控制項
位置資訊,Android 10 推出了 ACCESS_BACKGROUND_LOCATION
權限。
與「ACCESS_FINE_LOCATION
」不同
和ACCESS_COARSE_LOCATION
權限,ACCESS_BACKGROUND_LOCATION
權限只會影響
應用程式在背景執行時存取位置資訊的權限。除非符合下列任一條件,否則系統會視為應用程式在背景存取位置資訊:
- 屬於應用程式的活動會顯示在畫面上。
- 應用程式正在執行已宣告前景服務的前景服務
「
location
」服務類型。
如何聲明前景服務 為應用程式中的服務類型,請設定應用程式的targetSdkVersion
或compileSdkVersion
到29
以上版本。進一步瞭解 前景服務如何持續 需要存取位置資訊的使用者啟動動作。
外部儲存空間
根據預設,指定 Android 10 以上版本為目標版本的應用程式會取得外部儲存空間的範圍存取權,或稱為限定範圍儲存空間。這類應用程式的可查看 外部儲存裝置中的下列類型檔案, 要求任何儲存空間相關使用者權限:
- 使用
getExternalFilesDir()
存取的應用程式專屬目錄中的檔案。 - 應用程式從媒體商店建立的相片、影片和音訊片段。
如要進一步瞭解限定範圍儲存空間,以及如何共用、存取和 修改儲存在外部儲存裝置中的檔案,請參閱指南,瞭解做法 即可管理 外部儲存空間中的檔案,以及存取檔案 和修改媒體檔案
MAC 位址隨機化
在搭載 Android 10 以上版本的裝置上,系統會傳輸隨機 MAC
地址。
如果應用程式處理企業用途,平台會提供與 MAC 位址相關的多項作業 API:
- 取得隨機 MAC 位址:裝置擁有者應用程式和
設定檔擁有者應用程式可以擷取指派給
呼叫
getRandomizedMacAddress()
來處理特定網路。 - 取得實際的原廠 MAC 位址:裝置擁有者應用程式可
呼叫
getWifiMacAddress()
以擷取裝置的實際硬體 MAC 位址。 這個方法適合用於追蹤裝置機隊。
無法重設的裝置 ID
自 Android 10 起,應用程式必須具備 READ_PRIVILEGED_PHONE_STATE
特權才能存取裝置的無法重設 ID,包括 IMEI 和序號。
Build
TelephonyManager
如果應用程式不具備權限,但您嘗試要求提供資訊 至於無法重設的 ID,平台的回應會因 目標 SDK 版本:
- 如果應用程式指定 Android 10 以上版本,就會發生
SecurityException
。 - 如果應用程式指定 Android 9 (API 級別 28) 以下版本,且應用程式具有
READ_PHONE_STATE
權限,則該方法會傳回null
或預留位置資料。否則會發生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
類別。
已從 UI 中移除權限群組
自 Android 10 起,應用程式無法在 UI 中查詢權限分組方式。
移除聯絡人相依性
自 Android 10 起,平台不會追蹤聯絡人親和力資訊。因此,如果您的應用程式針對使用者的聯絡人執行搜尋,
而不依互動頻率排序。ContactsProvider
指南包含一則通知,說明從 Android 10 開始,所有裝置上已淘汰的特定欄位和方法。
限制存取畫面內容
為保護使用者的螢幕內容,Android 10 會變更 READ_FRAME_BUFFER
、CAPTURE_VIDEO_OUTPUT
和 CAPTURE_SECURE_VIDEO_OUTPUT
權限的範圍,防止對裝置螢幕內容進行無聲存取。自 Android 10 起,這些權限僅限簽名存取。
需要存取裝置畫面內容的應用程式應使用
MediaProjection
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 以上版本,且不是系統應用程式或
則以下方法不會傳回有用資料:
getConfiguredNetworks()
此方法一律會傳回空白清單。- 每個會傳回整數值的網路作業方法 (
addNetwork()
和updateNetwork()
) 一律會傳回 -1。 - 各項傳回布林值的網路作業:
removeNetwork()
、reassociate()
,enableNetwork()
、disableNetwork()
、reconnect()
、 和disconnect()
—一律 會傳回false
。
Android 9
每個 Android 版本都包含數十項安全性強化功能,可保護使用者。如需 Android 9 中提供的部分主要安全性增強功能清單,請參閱 Android 版本資訊。
Android 8
每個 Android 版本都包含數十項安全性增強措施 使用者。以下列舉 Android 應用程式的一些主要安全性強化功能 8.0:
- 加密。支援在工作資料夾中新增撤銷金鑰。
- 驗證開機程序。新增 Android 驗證開機程序 (AVB)。已驗證的 Boot 程式碼庫,可在 AOSP 中使用啟動載入器的回溯保護功能。推薦系統啟動載入程式支援,以便確保您對應用程式的復原程序 HLOS。建議使用者必須實際操作,才能解鎖啟動載入器 與使用者保持連線
- 螢幕鎖定。新增使用防竄改硬體驗證鎖定螢幕憑證的支援功能。
- KeyStore。所有搭載 Android 8.0 以上版本的裝置都需要金鑰認證。新增ID 認證支援功能,以改善零接觸註冊程序。
- 採用沙箱機制。使用 Project Treble 的標準介面,在架構和裝置專屬元件之間,為許多元件提供更嚴密的沙箱。已套用 seccomp 篩選所有不受信任的應用程式,減少核心的攻擊面。WebView 目前會在隔離程序中執行,對系統其他部分的存取權非常有限。
- 核心強化。已實作強化 usercopy、PAN 模擬、init 之後的唯讀,以及 KASLR。
- 使用者空間強化。為媒體堆疊實作 CFI。應用程式疊加層無法再覆蓋系統重要視窗,使用者可以關閉疊加層。
- 串流 OS 更新。在磁碟空間不足的裝置上啟用更新。
- 安裝不明應用程式。使用者必須授予權限,才能從非第一方應用程式商店的來源安裝應用程式。
- 隱私權:每個應用程式和裝置上的每位使用者,都有不同的 Android ID (SSAID) 值。如果是網路瀏覽器應用程式,Widevine 用戶端 ID
會針對各個應用程式套件名稱和網路來源傳回不同的值。
net.hostname
現已空白,且 DHCP 用戶端不再傳送主機名稱。android.os.Build.SERIAL
已改為Build.SERIAL
API,並受到使用者控管的權限保護。改善的 MAC 位址 來隨機化。
Android 7
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。以下是 Android 7.0 中提供的一些主要安全增强功能:
- 文件级加密:在文件级进行加密,而不是将整个存储区域作为单个单元进行加密。这种加密方式可以更好地隔离和保护设备上的不同用户和资料(例如个人资料和工作资料)。
- 直接启动:通过文件级加密实现,允许特定应用(例如,闹钟和无障碍功能)在设备已开机但未解锁的情况下运行。
- 验证启动:现在,验证启动会被严格强制执行,从而使遭到入侵的设备无法启动;验证启动支持纠错功能,有助于更可靠地防范非恶意数据损坏。
- SELinux。更新后的 SELinux 配置和更高的 Seccomp 覆盖率有助于进一步锁定应用沙盒并减小受攻击面。
- 库加载顺序随机化和改进的 ASLR。 增大随机性降低了某些代码重用攻击的有效性。
- 内核加固:通过将内核内存的各个分区标记为只读,限制内核对用户空间地址的访问,并进一步减小现有的受攻击面,为更高版本的内核添加额外的内存保护。
- APK 签名方案 v2:引入了一种全文件签名方案,该方案有助于加快验证速度并增强完整性保证。
- 可信 CA 存储区。为了使应用更容易控制对其安全网络流量的访问,对于 API 级别为 24 及以上的应用,由用户安装的证书颁发机构以及通过 Device Admin API 安装的证书颁发机构在默认情况下不再受信任。此外,所有新的 Android 设备必须搭载相同的可信 CA 存储区。
- 网络安全配置。通过声明式配置文件来配置网络安全设置和传输层安全协议 (TLS)。
Android 6
每个 Android 版本中都包含数十种用于保护用户的安全增强功能。以下是 Android 6.0 中提供的一些主要安全增强功能:
- 运行时权限:应用在运行时请求权限,而不是在安装时被授予权限。用户可以为 M 及更低版本的 Android 应用启用和停用权限。
- 验证启动:在执行系统软件之前,先对其进行一系列加密检查,以确保手机从引导加载程序到操作系统均处于正常状况。
- 硬件隔离安全措施:新的硬件抽象层 (HAL),Fingerprint API、锁定屏幕、设备加密功能和客户端证书可以利用它来保护密钥免遭内核入侵和/或现场攻击。
- 指纹:现在,只需触摸一下,即可解锁设备。开发者还可以借助新的 API 来使用指纹锁定和解锁加密密钥。
- 加装 SD 卡:可将移动媒体设备加装到设备上,以便扩展可用存储空间来存放本地应用数据、照片、视频等内容,但仍受块级加密保护。
- 明文流量:开发者可以使用新的 StrictMode 来确保其应用不会使用明文。
- 系统加固:通过由 SELinux 强制执行的政策对系统进行加固。这可以实现更好的用户隔离和 IOCTL 过滤、降低可从设备/系统之外访问的服务面临的威胁、进一步强化 SELinux 域,以及高度限制对 /proc 的访问。
- USB 访问控制:必须由用户确认是否允许通过 USB 访问手机上的文件、存储空间或其他功能。现在,默认设置是“仅充电”,如果要访问存储空间,必须获得用户的明确许可。
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 以下版本
每个 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 的某些设备可能也会包含这些修复程序。
每个 Android 版本中都包含数十项用于保护用户的安全增强功能。以下是 Android 4.3 中提供的一些安全增强功能:
- 通过 SELinux 得到增强的 Android 沙盒。此版本利用 Linux 内核中的 SELinux 强制访问权限控制系统 (MAC) 增强了 Android 沙盒。SELinux 强化功能(用户和开发者看不到它)可提高现有 Android 安全模型的可靠性,同时与现有应用保持兼容。为了确保持续兼容,此版本允许以宽容模式使用 SELinux。此模式会记录所有政策违规行为,但不会中断应用或影响系统行为。
- 没有 setuid/setgid 程序。针对 Android 系统文件添加了对文件系统功能的支持,并移除了所有 setuid/setgid 程序。 这可以减小 root 攻击面,并降低出现潜在安全漏洞的可能性。
- ADB 身份验证。从 Android 4.2.2 起,开始使用 RSA 密钥对为 ADB 连接进行身份验证。这可以防止攻击者在实际接触到设备的情况下未经授权使用 ADB。
- 限制 Android 应用执行 SetUID 程序。/system 分区现在针对 Zygote 衍生的进程装载了 nosuid,以防止 Android 应用执行 setuid 程序。这可以减小 root 攻击面,并降低出现潜在安全漏洞的可能性。
- 功能绑定。在执行应用之前,Android Zygote 和 ADB 现在会先使用 prctl(PR_CAPBSET_DROP) 舍弃不必要的功能。这可以防止 Android 应用和从 shell 启动的应用获取特权功能。
- AndroidKeyStore 提供程序。Android 现在有一个允许应用创建专用密钥的密钥库提供程序。该程序可以为应用提供一个用于创建或存储私钥的 API,其他应用将无法使用这些私钥。
- KeyChain isBoundKeyAlgorithm。Keychain API 现在提供了一种方法 (isBoundKeyType),可让应用确认系统级密钥是否已绑定到设备的硬件信任根。该方法提供了一个用于创建或存储私钥的位置,即使发生 root 权限被窃取的情况,这些私钥也无法从设备中导出。
- NO_NEW_PRIVS。在执行应用代码之前,Android Zygote 现在会先使用 prctl(PR_SET_NO_NEW_PRIVS) 禁止添加新权限。这可以防止 Android 应用执行可通过 execve 提权的操作。(此功能需要使用 3.5 或更高版本的 Linux 内核)。
- FORTIFY_SOURCE 增强功能。Android x86 和 MIPS 上启用了 FORTIFY_SOURCE,并增强了 strchr()、strrchr()、strlen() 和 umask() 调用。这可以检测潜在的内存损坏漏洞或没有结束符的字符串常量。
- 重定位保护。针对静态关联的可执行文件启用了只读重定位 (relro) 技术,并移除了 Android 代码中的所有文本重定位技术。这可以深度防范潜在的内存损坏漏洞。
- 经过改进的 EntropyMixer。除了定期执行混合操作之外,EntropyMixer 现在还会在关机/重新启动时写入熵。这样一来,便可以保留设备开机时生成的所有熵,而这对于配置之后立即重新启动的设备来说尤其有用。
- 安全修复。Android 4.3 中还包含针对 Android 特有漏洞的修复。有关这些漏洞的信息已提供给“开放手机联盟”(Open Handset Alliance) 成员,并且 Android 开放源代码项目中提供了相应的修复。为了提高安全性,搭载更低版本 Android 的某些设备可能也会包含这些修复。
Android 提供多層式安全性模型 (詳見 Android 安全性總覽。每個 Android 更新都包含數十項安全性強化功能,可保護使用者。以下是 Android 4.2 中推出的部分安全性強化功能:
- 應用程式驗證:使用者可選擇啟用「驗證應用程式」,並 的應用程式在安裝前是由應用程式驗證器檢查。 如果使用者嘗試安裝可能有害的應用程式,應用程式驗證功能就會發出警示;如果應用程式特別危險,系統會封鎖安裝作業。
- 進一步控管付費簡訊:如果應用程式嘗試傳送簡訊給使用付費服務的簡碼,而該服務可能會產生額外費用,Android 會提供通知。使用者可以選擇是否允許 來傳送訊息或封鎖訊息
- 永久連線 VPN:您可以設定 VPN,讓應用程式停止 可存取網路,直到建立 VPN 連線為止。這麼做可以避免 應用程式傳送資料給其他網路。
- 憑證綁定:Android 核心程式庫現已支援 綁定憑證。 如果憑證未鏈結至一組預期的憑證,則已固定的網域會收到憑證驗證失敗的通知。這可防範憑證授權單位遭到入侵。
- 改善 Android 權限的顯示方式:權限會分組,方便使用者瞭解。在審查權限期間,使用者可以按一下權限,查看權限的詳細資訊。
- 安裝強化:
installd
Daemon 並未以 ,減少 Root 權限提升的潛在受攻擊面。 - init 指令碼強化:init 指令碼現在會套用
O_NOFOLLOW
語意 以防止符號連結相關攻擊 FORTIFY_SOURCE
:Android 現在會實作FORTIFY_SOURCE
。系統程式庫和應用程式會使用此值,以防記憶體毀損。- ContentProvider 預設設定:針對以 API 級別 17 為目標的應用程式,每個 Content Provider 的
export
預設值皆為false
,可減少應用程式的預設攻擊面。 - 密碼編譯:修改 SecureRandom 和 Cipher.RSA 的預設實作項目,以便使用 OpenSSL。為 TLSv1.1 和 TLSv1.2 新增 SSL Socket 支援 使用 OpenSSL 1.0.1
- 安全性修正:升級的開放原始碼程式庫內含安全性修正項目 WebKit、libpng、OpenSSL 和 LibXML。Android 4.2 版還修正了以下項目: Android 專屬的安全漏洞。這些安全漏洞的相關資訊 提供給 Open Handset Alliance 成員。如需修正程式,請前往 Android 開放原始碼計畫。為提升安全性,部分搭載舊版作業系統的裝置 也可能包含這些修正程式。
Android provides a multi-layered security model described in the Android Security Overview. Each update to Android includes dozens of security enhancements to protect users. The following are some of the security enhancements introduced in Android versions 1.5 through 4.1:
- Android 1.5
- ProPolice to prevent stack buffer overruns (-fstack-protector)
- safe_iop to reduce integer overflows
- Extensions to OpenBSD dlmalloc to prevent double free() vulnerabilities and to prevent chunk consolidation attacks. Chunk consolidation attacks are a common way to exploit heap corruption.
- OpenBSD calloc to prevent integer overflows during memory allocation
- Android 2.3
- Format string vulnerability protections (-Wformat-security -Werror=format-security)
- Hardware-based No eXecute (NX) to prevent code execution on the stack and heap
- Linux mmap_min_addr to mitigate null pointer dereference privilege escalation (further enhanced in Android 4.1)
- Android 4.0
- Address Space Layout Randomization (ASLR) to randomize key locations in memory
- Android 4.1
- PIE (Position Independent Executable) support
- Read-only relocations / immediate binding (-Wl,-z,relro -Wl,-z,now)
- dmesg_restrict enabled (avoid leaking kernel addresses)
- kptr_restrict enabled (avoid leaking kernel addresses)