本文由 Migrant 翻譯自 The Complete Tutorial on iOS/iPhone Custom URL Schemes,轉載請注明出處。
注意: 自從自定義 URL 的引入,本文始終是我博客中閱讀量最大的文章。雖然大多數都相同,但仍然有一些細微差別的變化。本文是原帖的重寫版,更新為最新的 iOS 和 Xcode 版本。
iPhone / iOS SDK 最酷的特性之一就是應用將其自身”綁定”到一個自定義 URL scheme 上,該 scheme 用於從瀏覽器或其他應用中啟動本應用。
注冊自定義 URL Scheme
注冊自定義 URL Scheme 的第一步是創建 URL Scheme — 在 Xcode Project Navigator 中找到並點擊工程 info.plist 文件。當該文件顯示在右邊窗口,在列表上點擊鼠標右鍵,選擇 Add Row:
向下滾動彈出的列表並選擇 URL types。
點擊左邊剪頭打開列表,可以看到 Item 0,一個字典實體。展開 Item 0,可以看到 URL Identifier,一個字符串對象。該字符串是你自定義的 URL scheme 的名字。建議采用反轉域名的方法保證該名字的唯一性,比如 com.yourCompany.yourApp。
點擊 Item 0 新增一行,從下拉列表中選擇 URL Schemes,敲擊鍵盤回車鍵完成插入。
注意 URL Schemes 是一個數組,允許應用定義多個 URL schemes。
展開該數據並點擊 Item 0。你將在這里定義自定義 URL scheme 的名字。只需要名字,不要在后面追加 :// — 比如,如果你輸入 iOSDevApp,你的自定義 url 就是 iOSDevApp://
此時,整個定義如下圖:
雖然我贊同 Xcode 使用描述性的名字的目的,不過看到創建的實際的 key 也是非常有用的。這里有一個方便的技巧,右鍵點擊 plist 並選擇 Show Raw Keys/Values,就能看到以下效果:
還有另一種有用的輸出格式,XML,因為可以非常容易的看到字典和原始數組及其包括的實體的結構。點擊 plist 並選擇 Open As – Source Code:
從 Safari 中調用自定義 URL Scheme
定義了 URL scheme,我們可以運行一個快速測試來驗證應用是否如我們所期望的被調用。在這之前,我創建了一個准 UI 以辨別帶有自定義 URL 的應用。該應用只有一個 UILabel,帶有文本 “App With Custom URL”。下載源代碼
使用模擬器調用應用的步驟:
- 在 Xcode 中運行應用
- 一旦應用被安裝,自定義 URL scheme 就會被注冊
- 通過模擬器的硬件菜單中選擇 Home 來關閉應用
- 啟動 Safari
- 在瀏覽器地址欄輸入之前定義的 URL scheme(如下)
Call Custom URL Scheme from Safari
此時 Safari 將會關閉,應用會被帶回到前台。祝賀你剛剛使用自定義 URL scheme 調用了一個 iPhone 應用。
從另一個 iPhone 應用中調用自定義 URL Scheme
讓我們看看如何從另一個應用中調用自定義 URL scheme。我又創建了一個非常簡單的 iPhone 應用,它只有一個 UILabel 和一個 UIButton — 前者顯示了一段信息,告訴你這個應用將要通過自定義 URL scheme 來調用另一個應用,按鈕則開始這個行為。下載源代碼
iPhone app that call Custom URL Scheme
buttonPressed 方法中的代碼處理 URL 調用:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
|
第 5 行代碼檢查自定義 URL 是否被定義,如果定義了,則使用 shared application 實例來打開 URL (第 8 行)。openURL: 方法啟動應用並將 URL 傳入應用。在此過程中,當前的應用被退出。
通過自定義 URL Scheme 向應用傳遞參數
有時你需要通過自定義 URL 向應用中傳遞參數。讓我們看看該如何完成這個工作。
NSURL 作為從一個應用調用另一個的基礎,遵循 RFC 1808 (Relative Uniform Resource Locators) 標准。 因此你所熟悉的基於網頁內容的 URL 格式在這里也適用。
在自定義了 URL scheme 的應用中,app delegate 必須實現以下方法:
1
2 3 4 |
|
從一個應用傳遞參數到另一個的訣竅是通過 URL。例如,假設我們使用以下的 URL scheme,想傳遞一個名為 “token”的參數和一個標識注冊狀態的標志,我們可以像這樣創建一個 URL:
1
|
|
在 web 開發中,字符串 ?token=123abct®istered=1 被稱作查詢詢串(query string).
在被調用(設置了自定義 URL)的應用的 app delegate 中,獲取參數的代碼如下:
1
2 3 4 5 6 7 8 9 |
|
以上代碼在應用被調用時的輸出為:
1
2 3 |
|
注意 “Calling Application Bundle ID”,你可以用這個來確保只有你定義的應用可以與你的應用直接交互。
讓我們改變一下代碼,來驗證發起調用的應用的 Bundle ID 是否合法:
1
2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
有一點要特別注意,你不能阻止其他應用通過自定義 URL scheme 調用你的應用,然而你可以跳過后續的操作並返回 NO,就像上面的代碼那樣。也就是說,如果你想阻止其它應用調用你的應用,創建一個與眾不同的 URL scheme。盡管這不能保證你的應用不會被調用,但至少大大降低了這種可能性。
自定義 URL Scheme 示例工程
我意識到按照本文的每一步做下來還是有一點復雜的。我做好了兩個非常基礎的 iOS 應用,一個自定義了 URL scheme,另一個則去調用它,並傳遞了一個比較短的參數列表(query string)。這些是體驗自定義 URL 的很好的入門點。
- Download Xcode project for app with Custom URL scheme
- Download Xcode project for app to call custom URL scheme
其它資源
How to Properly Validate URL Parameters URL Scheme Reference Docs