亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android13?加強Intent?filters?的安全性

 更新時間:2022年05月26日 11:30:39   作者:??TechMerger????  
這篇文章主要介紹了Android13?加強Intent?filters?的安全性,文章基于Android13?展開Intent?filters?安全性加強的詳細介紹,需要的小伙伴可以參考一下

前言:

在看這個變更之前,我們需要回憶下 Android 12 的一個安全性變更, 即聲明了 <intent-filter> 的Activity、BroadcastReceiver、Service 必須聲明 android:exported, 否則將會無法被啟動。

Android 12 的這個變更是為了防止開發(fā)者在不知情的情況下,聲明了一個 intent-filter 就會使得這些組件對外公開,一定程度下強化了安全性。

但是卻漏掉了顯式 Intent 啟動和 Broadcast Receiver 動態(tài)注冊兩種情況,便在 13 中分別推出了兩項變更來進行加強。

  • Intent filters block non- -matching intents
  • Safer exporting of context- -registered receivers

Intent filters block non-matching intents

Android 13 開始 Intent 過濾器會屏蔽不匹配的 intent,即便是指定了 Component 的顯式啟動。

在 13 以前:

  • 開發(fā)者想給 Component 添加 支持
  • 這個 需要公開給外部 App 使用,便設定了 Component exported 為 true
  • 這時候該 Component 就出現(xiàn)了一個安全漏洞:外部 App 使用不同于 中聲明的 Action,甚至 mimeType 都不匹配均可以啟動它

也許你覺得這并沒有什么,但是如果 App 只針對 過來的 Route 做了安全校驗,就造成了校驗上的疏漏。

具體變更

假如我們提供了的 Activity 像如下一樣聲明:

<activity
    android:name=".MainActivity"
    android:exported="true">
    <intent-filter>
        <action android:name="android.intent.action.MAIN" />
        <category android:name="android.intent.category.LAUNCHER" />
    </intent-filter>
    <intent-filter>
        <action android:name="android.intent.action.TEST" />
        <data android:mimeType="vnd.android.cursor.dir/event"/>
    </intent-filter>
</activity>

在 13 之前,其他 App 采用了顯式啟動,即便是錯誤的 ACTION 是可以正常啟動我們的 Activity。

private fun testIntentFilters() {
    Intent().setComponent(
        ComponentName("com.example.demoapplication",
            "com.example.demoapplication.MainActivity")
    ).apply {
        action = "android.intent.action.TEST_A"
        startActivity(this)
    }
}

而運行在 13 上的話,將無法啟動并會發(fā)生如下錯誤:

PackageManager: Intent does not match component's intent filter: Intent { act=android.intent.action.TEST_A cmp=com.example.demoapplication/.MainActivity }

PackageManager: Access blocked: ComponentInfo{com.example.demoapplication/com.example.demoapplication.MainActivity}

除了 ACTION 修改正確以外,data 也要滿足即 Intent-filter 完全符合才可以啟動。

private fun testIntentFilters() {
    Intent().setComponent(
        ComponentName("com.example.demoapplication",
            "com.example.demoapplication.MainActivity")
    ).apply {
        action = "android.intent.action.TEST"
        data = CalendarContract.Events.CONTENT_URI
        startActivity(this)
    }
}

豁免

如下的幾種場景下的 Intent 并不在本次變更的影響范圍內(nèi):

  • 目標 Component 沒有聲明 <intent-filter>
  • 同一個 App 內(nèi)部發(fā)出的 Intent
  • 系統(tǒng)發(fā)出的 Intent,包括 SystemServer、采用 System UID 的系統(tǒng) App
  • Root 進程發(fā)出的 Intent

適配辦法

如果目標運行的版本基于 Android 13,并且不是上述豁免對象的話,需要做些檢查和必要的修改。

按照啟動方和目標方兩種情況進行適配辦法的探討:

  • 作為啟動方:
    • 是否存在采用顯式 Intent 方式啟動其他 App 或發(fā)送廣播的情況
      • startActivity()
      • startActivityForResult()
      • sendBroadcast()
    • 該 Component 是否聲明了 <intent-filter>
    • 防止其 Target 升級到了 Android 13 無法正常啟動,需要注意 Intent 的 action、data 等信息是否準確
  • 作為目標方:
    • Target 是否需要升級到 Android 13
    • 是否對外提供了 Component 并聲明了 <intent-filter>
    • 防止無法被正常啟動,需要告知啟動方 <intent-filter> 的信息

殘留

13 上實測發(fā)現(xiàn) Service 組件在顯式啟動下,即便是錯誤的 ACTION,仍能被正常啟動。這是有意為之還是 Beta 版漏洞,源碼尚未公開,原因未知。

  • startService()
  • startForegroundService()
  • bindService()

Safer exporting of context-registered receivers

為了幫助提高運行時接收器的安全性,Android 13 允許您指定您應用中的特定廣播接收器是否應被導出以及是否對設備上的其他應用可見。

如果導出廣播接收器,其他應用將可以向您的應用發(fā)送不受保護的廣播。此導出配置在以 Android 13 或更高版本為目標平臺的應用中可用,有助于防止一個主要的應用漏洞來源。

具體變更

TargetSDK 升級到 Android13 的 App 在動態(tài)注冊 Receiver 的時候不指明該 flag,那么會收到如下的 crash:

java.lang.SecurityException: com.example.demoapplication: One of RECEIVER_EXPORTED or RECEIVER_NOT_EXPORTED should be specified when a receiver isn't being registered exclusively for system broadcasts

目前上述限制不是默認生效的,需要開啟如下兼容性變更:

  • 開發(fā)者選項 -> App Compatibility Changes -> Your App -> DYNAMIC_RECEIVER_EXPLICIT_EXPORT_REQUIRED

另外,當你的 Receiver 聲明了 RECEIVER_NOT_EXPORTED 的話,其他 App 向其發(fā)送廣播會失敗,并打印如下日志提醒你的 Receiver 需要公開:

BroadcastQueue: Exported Denial: sending Intent { act=com.example.demoapplication.RECEIVER flg=0x10 }, action: com.example.demoapplication.RECEIVER from com.example.tiramisu_demo (uid=10161)

due to receiver ProcessRecord{8e5f11c 16942:com.example.demoapplication/u0a158} (uid 10158) not specifying RECEIVER_EXPORTED

豁免

需要留意的是,系統(tǒng)級廣播是受保護的,普通 App 沒有權限發(fā)送。

所以只是監(jiān)聽系統(tǒng)廣播的話,動態(tài)注冊的 Receiver 無需指定上述 flag。即便指定了 RECEIVER_NOT_EXPORTED,和靜態(tài)注冊方式一致也能正常接收、不受影響。

適配辦法

找到所有動態(tài)注冊 Broadcast Receiver 的代碼。如果監(jiān)聽的包含非系統(tǒng)廣播,請根據(jù)是否公開給其他 App 的需要使用來添加 flag 的聲明。

  • RECEIVER_EXPORTED
  • RECEIVER_NOT_EXPORTED
context.registerReceiver(sharedBroadcastReceiver, intentFilter,
    RECEIVER_EXPORTED)
context.registerReceiver(privateBroadcastReceiver, intentFilter,
    RECEIVER_NOT_EXPORTED)

結語

無論是針對 Intent Fitler 匹配的要求升級還是動態(tài)注冊的 Receiver Flag,都是為了增強組件安全。希望開發(fā)者在對待這些習以為常的三大組件時,多些思考、避免漏洞百出。

到此這篇關于Android13 加強Intent filters 的安全性的文章就介紹到這了,更多相關Android Intent filters 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Kotlin面向?qū)ο笾R點講解

    Kotlin面向?qū)ο笾R點講解

    面向?qū)ο缶幊掏ㄟ^對事物的抽象,大大的簡化了程序的開發(fā)難度。我們常用的編程語言:Java、C++、Python都屬于面向?qū)ο缶幊?。Kotlin與java類似,也是一種面向?qū)ο缶幊陶Z言。本文從面向?qū)ο笕齻€基本特征:封裝、繼承、多態(tài),來闡述一下Kotlin中的面向?qū)ο缶幊?/div> 2022-12-12
  • Android百度地圖實現(xiàn)搜索和定位及自定義圖標繪制并點擊時彈出泡泡

    Android百度地圖實現(xiàn)搜索和定位及自定義圖標繪制并點擊時彈出泡泡

    這篇文章主要介紹了Android百度地圖實現(xiàn)搜索和定位及自定義圖標繪制并點擊時彈出泡泡的相關資料,需要的朋友可以參考下
    2016-01-01
  • Android自定義View圓形和拖動圓、跟隨手指拖動效果

    Android自定義View圓形和拖動圓、跟隨手指拖動效果

    單純的自定義一個圓非常簡單 只需要幾步就完成 拖動圓添加實現(xiàn)觸摸事件即可 。接下來通過本文給大家分享Android自定義View圓形和拖動圓、跟隨手指拖動效果,感興趣的朋友一起看看吧
    2017-09-09
  • Android中區(qū)別Drawable Bitmap Canvas Paint

    Android中區(qū)別Drawable Bitmap Canvas Paint

    本文主要介紹Android中Drawable Bitmap Canvas Paint 之間的區(qū)別,這里對這幾個概念做出詳細介紹,開發(fā)Android游戲的朋友可以參考下
    2016-07-07
  • Android本地視頻壓縮方案的示例代碼

    Android本地視頻壓縮方案的示例代碼

    本篇文章主要介紹了Android本地視頻壓縮方案的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • 微信舉報解除和微信解除限制的6個方法

    微信舉報解除和微信解除限制的6個方法

    本文主要介紹微信被舉報怎么解除?微信解除限制,這里整理了6種方法,有需要的小伙伴可以參考下
    2016-09-09
  • 詳解Flutter?響應式狀態(tài)管理框架GetX

    詳解Flutter?響應式狀態(tài)管理框架GetX

    這篇文章主要為大家介紹了Flutter?響應式狀態(tài)管理框架GetX詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • Android 中三種啟用線程的方法總結

    Android 中三種啟用線程的方法總結

    下面小編就為大家?guī)硪黄狝ndroid 中三種啟用線程的方法總結。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-02-02
  • android第三方分享方式的簡單實現(xiàn)

    android第三方分享方式的簡單實現(xiàn)

    這篇文章主要為大家詳細介紹了android第三方分享方式的簡單實現(xiàn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • Activity實例詳解之啟動activity并返回結果

    Activity實例詳解之啟動activity并返回結果

    這篇文章主要介紹了Activity實例詳解之啟動activity并返回結果 的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2016-09-09

最新評論