Android應用安全開發之淺談網頁打開APP

来源:http://www.cnblogs.com/alisecurity/archive/2016/04/21/5417663.html
-Advertisement-
Play Games

一、網頁打開APP簡介 Android有一個特性,可以通過點擊網頁內的某個鏈接打開APP,或者在其他APP中通過點擊某個鏈接打開另外一個APP(AppLink),一些用戶量比較大的APP,已經通過發佈其AppLink SDK,開發者需要申請相應的資格,配置相關內容才能使用。這些都是通過用戶自定義的U ...


一、網頁打開APP簡介

Android有一個特性,可以通過點擊網頁內的某個鏈接打開APP,或者在其他APP中通過點擊某個鏈接打開另外一個APP(AppLink),一些用戶量比較大的APP,已經通過發佈其AppLink SDK,開發者需要申請相應的資格,配置相關內容才能使用。這些都是通過用戶自定義的URI scheme實現的,不過背後還是Android的Intent機制。Google的官方文檔《Android Intents with Chrome》一文,介紹了在Android Chrome瀏覽器中網頁打開APP的兩種方法,一種是用戶自定義的URI scheme(Custom URI scheme),另一種是“intent:”語法(Intent-based URI)。

 

第一種用戶自定義的URI scheme形式如下:

 

第二種的Intent-based URI的語法形式如下:

因為第二種形式大體是第一種形式的特例,所以很多文章又將第二種形式叫Intent Scheme URL,但是在Google的官方文檔並沒有這樣的說法。

 

註意:使用Custom URI scheme給APP傳遞數據,只能使用相關參數來傳遞數據,不能想當然的使用scheme://host#intent;參數;end的形式來構造傳給APP的intent數據。詳見3.1節的說明。

此外,還必須在APP的Androidmanifest文件中配置相關的選項才能產生網頁打開APP的效果,具體在下麵講。

 

二、Custom Scheme URI打開APP

2.1 基本用法

需求:使用網頁打開一個APP,並通過URL的參數給APP傳遞一些數據。 

如自定義的Scheme為:

註意: uri要用UTF-8編碼和URI編碼。

 

網頁端的寫法如下:

 

APP端接收來自網頁信息的Activity,要在Androidmanifest.xml文件中Activity的intent-filter中聲明相應action、category和data的scheme等。 

如在MainActivity中接收從網頁來的信息,其在AndroidManifest.xml中的內容如下:

 

在MainActivity中接收intent並且獲取相應參數的代碼:

另外還有以下幾個API來獲取相關信息: 

getIntent().getScheme(); //獲得Scheme名稱 

getIntent().getDataString(); //獲得Uri全部路徑 

getIntent().getHost(); //獲得host

 

2.2 風險示例

常見的用法是在APP獲取到來自網頁的數據後,重新生成一個intent,然後發送給別的組件使用這些數據。比如使用Webview相關的Activity來載入一個來自網頁的url,如果此url來自url scheme中的參數,如:jaq://jaq.alibaba.com?load_url=http://www.taobao.com

 

如果在APP中,沒有檢查獲取到的load_url的值,攻擊者可以構造釣魚網站,誘導用戶點擊載入,就可以盜取用戶信息。

 

接2.1的示例,新建一個WebviewActivity組件,從intent裡面獲取load_url,然後使用Webview載入url:

 

修改MainActivity組件,從網頁端的URL中獲取load_url參數的值,生成新的intent,並傳給WebviewActivity:

 

網頁端:

 

釣魚頁面:

 

點擊“打開釣魚網站”,進入APP,並且APP載入了釣魚網站:

 

本例建議: 

在Webview載入load_url時,結合APP的自身業務採用白名單機制過濾網頁端傳過來的數據,黑名單容易被繞過。

 

2.3 阿裡聚安全對開發者建議

1、APP中任何接收外部輸入數據的地方都是潛在的攻擊點,過濾檢查來自網頁的參數。

 

2、不要通過網頁傳輸敏感信息,有的網站為了引導已經登錄的用戶到APP上使用,會使用腳本動態的生成URL Scheme的參數,其中包括了用戶名、密碼或者登錄態token等敏感信息,讓用戶打開APP直接就登錄了。惡意應用也可以註冊相同的URL Sechme來截取這些敏感信息。Android系統會讓用戶選擇使用哪個應用打開鏈接,但是如果用戶不註意,就會使用惡意應用打開,導致敏感信息泄露或者其他風險。

 

三、Intent-based URI打開APP

3.1基本用法

Intent-based URI語法:

 

註意:第二個Intent的第一個字母一定要大寫,不然不會成功調用APP。

 

如何正確快速的構造網頁端的intent? 

可以先建個Android demo app,按正常的方法構造自己想打開某個組件的Intent對象,然後使用Intent的toUri()方法,會得到Intent對象的Uri字元串表示,並且已經用UTF-8和Uri編碼好,直接複製放到網頁端即可,切記前面要加上“intent:”。 

 

如:

 

結果:

S.load_url是跟的是intent對象的putExtra()方法中的數據。其他類型的數據可以一個個試。如果在demo中的Intent對象不能傳遞給目標APP的Activity或其他組件,則其Uri形式放在網頁端也不可能打開APP的,這樣寫個demo容易排查錯誤。

 

APP端中的Androidmanifest.xml的聲明寫法同2.1節中的APP端寫法完全一樣。對於接收到的uri形式的intent,一般使用Intent的parseUri()方法來解析產生新的intent對象,如果處理不當會產生Intent Scheme URL攻擊。

 

為何不能用scheme://host#intent;參數;end的形式來構造傳給APP的intent數據? 

這種形式的intent不會直接被Android正確解析為intent,整個scheme字元串數據可以使用Intent的getDataSting()方法獲取到。 

如對於:

 

在APP中獲取數據:

 

結果是:

 

由上圖可知Android系統自動為Custom URI scheme添加了預設的intent。 

 

要想正確的解析,還需使用Intent的parseUri()方法對getDataString()獲取到的數據進行解析,如:

 

3.2 風險示例

關於Intent-based URI的風險我覺得《Android Intent Scheme URLs攻擊》《Intent Scheme URL attack》這兩篇文章寫的非常好,基本把該說的都都說了,我就不多說了,大家看這兩篇文章吧。

 

3.3 阿裡聚安全對開發者建議

上面兩篇文章中都給出了安全使用Intent Scheme URL的方法:

 

除了以上的做法,還是不要信任來自網頁端的任何intent,為了安全起見,使用網頁傳過來的intent時,還是要進行過濾和檢查。

 

四、參考

[1] Android Intents with Chrome,https://developer.chrome.com/multidevice/android/intents 

[2] Intent scheme URL attack,http://drops.wooyun.org/papers/2893 

[3] Android Appliaction Secure Design/Secure Coding Guidebook,http://www.jssec.org/dl/android_securecoding_en.pdf 

[4] Handling App Links,http://developer.android.com/intl/zh-cn/training/app-links/index.html 

[5] Android M App Links: 實現, 缺陷以及解決辦法,http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2015/0718/3200.html 

[6] Android Intent Scheme URLs攻擊,http://blog.csdn.net/l173864930/article/details/36951805

 

作者:伊樵,呆狐,舟海@阿裡移動安全,更多技術文章,請點擊阿裡聚安全博客

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 通過使用單行代碼完成同樣的 10 個練習,我們來看看 Swift 和其他語言之間的較量。 將數組中每個元素的值乘以 2 使用map來實現 代碼簡單明瞭地完成了數組元素乘2 求一組數字的和 這個問題可以通過使用 reduce 方法和加號運算符解決,這是因為加號運算符實際上也是一個函數。不過這個解法是非 ...
  • 使用小米號碼歸屬地資料庫,有兩張表data1和data2 先查詢data1表,把手機號碼截取前7位 select outkey from data1 where id=”前七位手機號” 再查詢data2表, select location from data2 where id=”上面查出的outk ...
  • 一、前言部分 沒發現蒲公英之前一直採用非常傻B的方式給公司App做內部測試,要麼發個測試包讓公司測試人員用iTUnes 自己安裝 要麼苦逼的一個個在我Xcode上直接安裝測試包,操作起來又麻煩又苦逼,後來偶然發現了蒲公英感覺這貨還真不是一般 好用。直接上傳測試文件到他們平臺上傳成功後直接將測試地址發 ...
  • 1.一個人上臺階可以一次上1個,2個,或者3個,問這個人上32層的臺階,總共有幾種走法? 思路:先建立數學模型,設3步的走 i 次,2步的走 j 次, 1步的走 k 次,上了3*i + 2*j + 1*k = n個臺階.總共走 i + j + k 次, 等於把n個臺階的長度先劃分成 i + j + ...
  • 需求一:我們製作APP的不可能一個界面來實現所有需求的,我們需要多個界面的跳轉。每個界面各自實現對應的需求,代碼實現多控制器之間的跳轉大致分為三類。一類是使用UINavigationController 跳轉 ,一類是使用UITabBarController 實現多個控制器之間的跳轉,還有一類是使用 ...
  • (轉載請註明出處哦)具體的百度地圖許可權和apikey配置以及基礎地圖的配置不敘述,百度地圖定位可以看這個鏈接的http://blog.csdn.net/heweigzf/article/details/51084358,先來看一波搜索需要的基本佈局layout AutoCompleteTextVie ...
  • 如果要在xib和storyboard里為控制項添加圓角和外框寬度,只要這樣做就可以 layer.borderWidth 設置外框寬度屬性 layer.cornerRadius 設置圓角屬性 只要為屬性設置value值就可以了 當然修改完xib里看是看不出來的,要運行才看得到,效果如下 那如果要在xib ...
  • 有時候在項目中,為了保持前後頁面的推進方式跳轉方式一致,會在通過UIview上的控制項跳到另一個Controller上,所以,這時候就需要用到這種方式了,當然,present方法可以實現跳轉但是樣式可能不同,這時候在我的想法可以使用代理或者回調,當你不熟悉時,就用到了這個方法: 1.參考別人的方法: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...