国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質的職業(yè)教育機構

            手機站
            千鋒教育

            千鋒學習站 | 隨時隨地免費學

            千鋒教育

            掃一掃進入千鋒手機站

            領取全套視頻
            千鋒教育

            關注千鋒學習站小程序
            隨時隨地免費學習課程

            當前位置:首頁  >  技術干貨  > PendingIntent和Intent的區(qū)別?

            PendingIntent和Intent的區(qū)別?

            來源:千鋒教育
            發(fā)布人:xqq
            時間: 2023-10-11 17:14:52 1697015692

            一、PendingIntent和Intent的區(qū)別

            從結構上來說,PendingIntent 是 Intent 的包裝類,其內部持有一個代表最終意圖操作的 Intent(事實上,內部是通過 IIntentSender 間接持有)。它們的區(qū)別我認為可以概括為 3 個維度:

            1、執(zhí)行進程不同 —— PendingIntent 在其他進程執(zhí)行: Intent 通常會在創(chuàng)建進程中執(zhí)行,而 PendingIntent 通常不會在創(chuàng)建進程中執(zhí)行;2、執(zhí)行時間不同 —— PendingIntent 會延遲執(zhí)行: Intent 通常會立即執(zhí)行,而 PendingIntent 通常會延遲執(zhí)行,延遲到其他進程完成任務后再執(zhí)行,甚至延遲到創(chuàng)建進程消亡后。例如,在 場景 1 – 系統(tǒng)通知消息的點擊操作 中,即使發(fā)送系統(tǒng)通知消息的進程已經消亡了,依然不妨礙二級 Intent 的跳轉;3、執(zhí)行身份不同 —— PendingIntent 支持授權: PendingIntent 內部持有授權信息,支持其他應用以當前應用的身份執(zhí)行,這有利于避免嵌套 Intent 存在的安全隱患。而直接使用 Intent 的話,一般只能以當前應用的身份執(zhí)行(為什么說一般?因為有 Activity#startActivityAsUser() 這個 API,但一般你拿不到所需的參數)。

            為什么要使用 PendingIntent

            PendingIntent 的應用場景關鍵在于間接的 Intent 跳轉需求, 即先通過一級 Intent 跳轉到某個組件,在該組件完成任務后再間接地跳轉到二級的 Intent。PendingIntent 中的單詞 “pending” 指延遲或掛起,就是指它是延遲的或掛起的。例如,你在以下場景中就可以使用 PendingIntent:

            場景 1 – 系統(tǒng)通知消息的點擊操作場景 2 – 桌面微件的點擊操作場景 3 – 系統(tǒng)鬧鐘操作場景 4 – 第三方應用回調操作

            可以看到,在這些場景中,我們真正感興趣的操作是掛起的,并且該操作并不是由當前應用執(zhí)行,而是由某個外部應用來 “間接” 執(zhí)行的。例如,我們在發(fā)送系統(tǒng)通知消息時,會通過 PendingIntent 構造一個系統(tǒng)通知 Notification ,并調用 NotificationManagerCompat.notify(…) 發(fā)送通知,此時并不會直接執(zhí)行 PendingIntent。而是當系統(tǒng)顯示通知,并且用戶點擊通知時,才會由系統(tǒng)通知這個系統(tǒng)應用間接執(zhí)行 PendingIntent#send() ,而不是通過當前應用執(zhí)行。

            延伸閱讀:

            二、嵌套 Intent 存在的安全隱患

            隱患 1 – Client App: 由于 ClientCallbackActivity 是從另一個應用 Provider App 啟動的,因此該 Activity 必須暴露為 exported。這意味著除了 Provider App 可以啟動該 Activity 外,同時也給了惡意應用啟動該 Activity 的可能性。如果 ClientCallbackActivity 是一個普通的 Activity 還要說,要是 ClientCallbackActivity 是一個敏感或高風險的行為(例如支付回調),那么這就存在很大的安全隱患了;

            隱患 2 – Provider App: 由于嵌套的 Intent 是在 Provider App 的上下文中啟動的,那么二級 Intent 不僅可以正常啟動 Client App 中的 ClientCallbackActivity(打開 exported 時),還可以啟動 Provider App 中任意 Activity。這意味著給了惡意應用啟動 Provider App 中敏感或高風險的 Activity 的可能性,即使這個敏感的 Activity 事先已經關閉 exported。這說明 exported 機制失效了,也存在很大的安全隱患。

            聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
            10年以上業(yè)內強師集結,手把手帶你蛻變精英
            請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
            免費領取
            今日已有369人領取成功
            劉同學 138****2860 剛剛成功領取
            王同學 131****2015 剛剛成功領取
            張同學 133****4652 剛剛成功領取
            李同學 135****8607 剛剛成功領取
            楊同學 132****5667 剛剛成功領取
            岳同學 134****6652 剛剛成功領取
            梁同學 157****2950 剛剛成功領取
            劉同學 189****1015 剛剛成功領取
            張同學 155****4678 剛剛成功領取
            鄒同學 139****2907 剛剛成功領取
            董同學 138****2867 剛剛成功領取
            周同學 136****3602 剛剛成功領取
            相關推薦HOT