iOS中的實時遠程配置全紀錄

這篇文章主要給大家介紹了關於iOS中實時遠程配置的相關資料,文中通過示例代碼介紹的非常詳細,對各位iOS開發者們具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧

前言

當您需要快速推出遠程配置更改時該怎麼辦?也許你做的上次更改沒有成功,你想盡快撤消它們。或者您的應用中出現了問題,您需要禁用整個功能。

更頻繁地調用fetchWithExpirationDuration:completionHandler: (具有較少的到期時間)是一種方法,但Firebase不鼓勵這樣做。你冒着被下架的風險。

如果您需要使遠程配置緩存無效,而不必對短暫的到期時間進行硬編碼,該怎麼辦?而不是反覆詢問服務器更新,讓服務器在有更改時通知您。 Firebase遠程配置現在與雲功能集成,因此可以在配置發佈或回滾時觸發執行。這意味着您可以讓一個函數向您的應用發送靜默推送通知,讓它知道配置已更改。

在AppDelegate中觸發回調時,不會向用戶顯示靜默推送通知。通過將選項content_available設置爲true,您甚至可以在推送通知到達時讓iOS在後臺啓動您的應用程序(或恢復它)。一個問題:如果用戶手動殺死它,iOS將無法在後臺啓動您的應用程序。這將持續到下次重新啓動(第一次解鎖後)。除此之外,你沒有其他問題了。

實現

這個過程歸結爲:

  • 將應用程序訂閱到Firebase Cloud Messaging主題
  • 創建在遠程配置更改時觸發的雲功能
  • 處理AppDelegate中的靜音推送通知
  • 在下次啓動時使遠程配置緩存無效

如何設置Firebase雲消息傳遞超出了本文的範圍,但文檔是一個很好的起點。

1.訂閱到主題

推送通知啓動並運行後,我們需要將應用訂閱到主題。我們將專門用於遠程配置。

Messaging.messaging().subscribe(toTopic: "REMOTE_CONFIG") { error in
 if let error = error {
  debugPrint("Could not subscribe to Remote Config topic", error)
 }
}

2.創建一個雲服務

Cloud Function只是一個Node.js腳本,因此您需要在您的計算機上使用Node.js.在撰寫本文時,Cloud Functions支持Node v6或Node v8,其中v6是默認值。

獲得Node.js後,首先安裝Firebase CLI

npm install -g firebase-tools

然後使用CLI工具進行身份驗證。

firebase login

現在爲函數創建一個文件夾,cd進入它並初始化Firebase項目。

firebase init functions

這將啓動CLI嚮導。完成它,你就準備好了。

是時候添加將向REMOTE_CONFIG通道發送靜默推送通知的雲功能。在新創建的項目的函數目錄中,您將找到index.js。打開它並用以下內容替換內容:

const functions = require('firebase-functions');
const admin = require('firebase-admin');
​
admin.initializeApp(functions.config().firebase);
​
exports.pushConfig = functions.remoteConfig.onUpdate(versionMetadata => {
 // Create FCM payload to send data message to REMOTE_CONFIG topic.
 const payload = {
  data: {
   CONFIG_STATE: 'STALE'
  }
 };
​
 const options = {
  content_available: true
 };
​
 // Use the Admin SDK to send the ping via FCM.
 return admin
  .messaging()
  .sendToTopic('REMOTE_CONFIG', payload, options)
  .then(response => {
   console.log(response);
  
   return null;
  });
});

我們使用通知來傳遞帶有密鑰CONFIG_STATE的有效負載。這將向您的應用發出遠程配置數據已更改的信號。如有必要,選項content_available是必要的,以使iOS恢復應用程序或在後臺啓動它。

現在該功能已經到位,我們可以將其部署到Firebase,以便它可以運行。

firebase deploy --only functions

這將部署到firebase init函數中選擇的Firebase項目。要部署到另一個項目,首先使用firebase使用--add添加它。添加後,您可以使用my-project-alias切換運行firebase的項目。

3.處理遠程推送

我們需要在AppDelegate中實現方法:didReceiveRemoteNotification:fetchCompletionHandler:來處理傳入的推送通知。如果userInfo字典有密鑰CONFIG_STATE(我們添加到通知有效負載的那個),那麼它就是我們正在尋找的通知。

func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable: Any], fetchCompletionHandler completionHandler: @escaping (_: UIBackgroundFetchResult) -> Void) {
 if userInfo["CONFIG_STATE"] != nil {
  UserDefaults.standard.set(true, forKey: "CONFIG_STATE")
  UserDefaults.standard.synchronize()
 }
​
 completionHandler(UIBackgroundFetchResult.newData)
}

這裏很容易調用fetchWithExpirationDuration:completionHandler:具有非常少的到期時間,以便在那時檢索更新的值。但這樣做會使所有通知的應用實例在大致相同的時間請求新值。這很可能會使應用受到限制,因此我們會將其推遲到下一次發佈。

4. 使遠程配置緩存無效

我們只需要將標誌保存到UserDefaults並在獲取Remote Config值之前進行檢查。

var expirationDuration: TimeInterval = 43200 // 12hs of cache by default
​
if UserDefaults.standard.bool(forKey: "CONFIG_STATE") {
 UserDefaults.standard.set(false, forKey: "CONFIG_STATE")
 UserDefaults.standard.synchronize()
   
 expirationDuration = 0
}
​
RemoteConfig.fetch(withExpirationDuration: expirationDuration) { [weak self] status, error in
 RemoteConfig.remoteConfig().activateFetched()
}

如果配置已過時,我們將通過將到期持續時間設置爲0來繞過緩存。這將強制執行一次完全重新加載,而不必等待緩存過期。

這就是所有的設置。現在轉到“遠程配置”面板併發布更改。然後查看“功能”選項卡。它應該如下所示:

日誌應該註冊成功執行:

總結

避免輪詢Firebase服務器以進行遠程配置更新的一種方法是讓雲功能在發佈更改時向您的應用發送靜默推送通知。然後,應用程序可以使遠程配置緩存無效,並在下次啓動時請求新值。但要注意,手動關閉應用程序的用戶在重新啓動和解鎖手機之前不會收到這些推送通知。

好了,以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對神馬文庫的支持。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章