热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ios开发云服务器配置,iOS中的实时远程配置全纪录

前言当您需要快速推出远程配置更改时该怎么办?也许你做的上次更改没有成功,你想尽快撤消它们。或者您的应用中出现了问题,您需要禁用整个功能。更

前言

当您需要快速推出远程配置更改时该怎么办?也许你做的上次更改没有成功,你想尽快撤消它们。或者您的应用中出现了问题,您需要禁用整个功能。

更频繁地调用fetchWithExpirationDuration:completionHandler: (具有较少的到期时间)是一种方法,但Firebase不鼓励这样做。你冒着被下架的风险。

如果您需要使远程配置缓存无效,而不必对短暂的到期时间进行硬编码,该怎么办?而不是反复询问服务器更新,让服务器在有更改时通知您。 Firebase远程配置现在与云功能集成,因此可以在配置发布或回滚时触发执行。这意味着您可以让一个函数向您的应用发送静默推送通知,让它知道配置已更改。

fadce197edc374102955a22d040c04e7.png

在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向导。完成它,你就准备好了。

eb5a671d1f2449a4f40af13171e92130.png

是时候添加将向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来绕过缓存。这将强制执行一次完全重新加载,而不必等待缓存过期。

这就是所有的设置。现在转到“远程配置”面板并发布更改。然后查看“功能”选项卡。它应该如下所示:

e78d1689cdb36bf7a30cc849d055bdca.png

日志应该注册成功执行:

3f0c64908027e065376ea452abcead62.png

总结

避免轮询Firebase服务器以进行远程配置更新的一种方法是让云功能在发布更改时向您的应用发送静默推送通知。然后,应用程序可以使远程配置缓存无效,并在下次启动时请求新值。但要注意,手动关闭应用程序的用户在重新启动和解锁手机之前不会收到这些推送通知。

好了,以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。



推荐阅读
  • Node.js 教程第五讲:深入解析 EventEmitter(事件监听与发射机制)
    本文将深入探讨 Node.js 中的 EventEmitter 模块,详细介绍其在事件监听与发射机制中的应用。内容涵盖事件驱动的基本概念、如何在 Node.js 中注册和触发自定义事件,以及 EventEmitter 的核心 API 和使用方法。通过本教程,读者将能够全面理解并熟练运用 EventEmitter 进行高效的事件处理。 ... [详细]
  • 本文介绍了如何使用 Node.js 和 Express(4.x 及以上版本)构建高效的文件上传功能。通过引入 `multer` 中间件,可以轻松实现文件上传。首先,需要通过 `npm install multer` 安装该中间件。接着,在 Express 应用中配置 `multer`,以处理多部分表单数据。本文详细讲解了 `multer` 的基本用法和高级配置,帮助开发者快速搭建稳定可靠的文件上传服务。 ... [详细]
  • 单元测试:使用mocha和should.js搭建nodejs的单元测试
    2019独角兽企业重金招聘Python工程师标准BDD测试利器:mochashould.js众所周知对于任何一个项目来说,做好单元测试都是必不可少 ... [详细]
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 作为软件工程专业的学生,我深知课堂上教师讲解速度之快,很多时候需要课后自行消化和巩固。因此,撰写这篇Java Web开发入门教程,旨在帮助初学者更好地理解和掌握基础知识。通过详细记录学习过程,希望能为更多像我一样在基础方面还有待提升的学员提供有益的参考。 ... [详细]
  • CentOS 7环境下Jenkins的安装与前后端应用部署详解
    CentOS 7环境下Jenkins的安装与前后端应用部署详解 ... [详细]
  • TypeScript 实战分享:Google 工程师深度解析 TypeScript 开发经验与心得
    TypeScript 实战分享:Google 工程师深度解析 TypeScript 开发经验与心得 ... [详细]
  • 深入解析 Vue 中的 Axios 请求库
    本文深入探讨了 Vue 中的 Axios 请求库,详细解析了其核心功能与使用方法。Axios 是一个基于 Promise 的 HTTP 客户端,支持浏览器和 Node.js 环境。文章首先介绍了 Axios 的基本概念,随后通过具体示例展示了如何在 Vue 项目中集成和使用 Axios 进行数据请求。无论你是初学者还是有经验的开发者,本文都能为你解决 Vue.js 相关问题提供有价值的参考。 ... [详细]
  • 本文详细介绍了在 Ubuntu 系统上搭建 Hadoop 集群时遇到的 SSH 密钥认证问题及其解决方案。通过本文,读者可以了解如何在多台虚拟机之间实现无密码 SSH 登录,从而顺利启动 Hadoop 集群。 ... [详细]
  • 如何在Docker环境中顺利运行Node.js应用程序? ... [详细]
  • 本文介绍了 Vue 开发的入门指南,重点讲解了开发环境的配置与项目的基本搭建。推荐使用 WebStorm 作为 IDE,其下载地址为 。安装时请选择适合您操作系统的版本,并通过 获取激活码。WebStorm 是前端开发者的理想选择,提供了丰富的功能和强大的代码编辑能力。 ... [详细]
  • Vue应用预渲染技术详解与实践 ... [详细]
  • 在 Vue.js 中实现网络请求的方法与最佳实践包括使用 `vue-resource` 插件。首先,通过命令 `npm install vue-resource --save` 安装该插件,确保添加 `--save` 参数以将依赖项记录到 `package.json` 文件中。此外,推荐使用 `axios` 作为替代方案,因为它提供了更强大的功能和更好的性能。在项目中引入并配置 `axios`,可以实现更高效、灵活的网络请求管理。 ... [详细]
  • 本文探讨了如何通过检测浏览器类型来动态加载特定的npm包,从而优化前端性能。具体而言,仅在用户使用Edge浏览器时加载相关包,以提升页面加载速度和整体用户体验。此外,文章还介绍了实现这一目标的技术细节和最佳实践,包括使用User-Agent字符串进行浏览器识别、条件加载策略以及性能监控方法。 ... [详细]
  • 掌握PHP编程必备知识与技巧——全面教程在当今的PHP开发中,了解并运用最新的技术和最佳实践至关重要。本教程将详细介绍PHP编程的核心知识与实用技巧。首先,确保你正在使用PHP 5.3或更高版本,最好是最新版本,以充分利用其性能优化和新特性。此外,我们还将探讨代码结构、安全性和性能优化等方面的内容,帮助你成为一名更高效的PHP开发者。 ... [详细]
author-avatar
爱蜜儿小秋秋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有