根據預設,如果指定 Android 11 (API 級別 30) 以上版本的應用程式要查詢裝置上其他已安裝應用程式的資訊,系統會篩選這類資訊。這種篩選行為意味著應用程式無法偵測裝置上安裝的所有應用程式,這麼做能有效減少應用程式可存取但執行用途時不需要的潛在機密資訊。
此外,經過篩選的套件瀏覽權限也有助於如 Google Play 這類應用程式商店評估應用程式提供給使用者的隱私權與安全性。舉例來說,Google Play 會將已安裝應用程式的清單視為個人和機密的使用者資料。
有限的應用程式瀏覽權限會影響提供其他應用程式相關資訊的方法所傳回的結果,例如 queryIntentActivities()
、getPackageInfo()
和 getInstalledApplications()
。此外,有限的瀏覽權限也會影響與其他應用程式的明確互動,例如啟動其他應用程式的服務。
部分套件會自動授予瀏覽權限。您的應用程式隨時可以在對其他已安裝應用程式的查詢中偵測這些套件。如要查看其他套件,請使用 <queries>
元素宣告應用程式需要提高套件瀏覽權限。用途頁面會提供範例,說明如何選擇性提高套件瀏覽權限。該頁面所述的工作流程可讓您在實現常見應用程式互動情境的同時,保護使用者隱私。
在極少數情況下,當 <queries>
元素無法提供適當的套件瀏覽權限,您可以使用 QUERY_ALL_PACKAGES
權限。如果您在 Google Play 上發布應用程式,則應用程式必須獲得核准才能使用這項權限。
如果應用程式需要與其他應用程式互動,請參閱「測試套件瀏覽權限行為」頁面中的建議,瞭解如何根據套件瀏覽權限測試行為異動。
其他資源
如要進一步瞭解 Android 的套件瀏覽權限,請參閱下列資源:
網誌文章
- Android 11 中的套件瀏覽權限 (透過 Medium 提供)。