Firebase 简介以及 VS code 无法访问的问题
ztj100 2024-12-27 17:52 14 浏览 0 评论
最近在开发项目中有使用到 firebase ,在这里记录一下开发心得。
firebase 是谷歌推出的云产品,官方对其的定义是:Firebase是谷歌的移动平台,可以帮助您快速开发高质量的应用程序,并发展您的业务。
我在使用过程中的理解是:Firebase 是一个谷歌推出的 “低后端代码“ 开发平台,帮助开发者减少后端代码编写量。
firebase 主要包含 Authentication、Firestore、 Realtime Database、storage、hosting、functions 、plugins以及机器学习等模块
Authentication
大多数应用都需要了解用户的身份。了解用户的身份可以让应用将用户数据安全地保存在云端,并在用户的所有设备上为其提供一致的个性化体验。
Firebase 身份验证提供了后端服务、易用的 SDK 以及现成的界面库,以便向您的应用验证用户的身份。该功能支持通过密码、电话号码、主流联合身份提供商服务(如 Google、Facebook 和 Twitter 等)进行身份验证。
说简单点就是一套集成了手机号登录、邮箱登录、第三方登录的无需后端代码即可调用的 sdk
Firestore
Cloud Firestore 是一种灵活且可扩缩的数据库(类似于键值型存储数据库),适用于在 Firebase 和 Google Cloud Platform 上进行移动、Web 和服务器开发。与 Firebase Realtime Database 一样,它可以通过实时侦听器使您的数据在各个客户端应用之间保持同步,并为移动和 Web 应用提供离线支持,以帮助您构建无论网络延迟时间或互联网连接状况如何都能快速响应的应用。Cloud Firestore 还提供与其他 Firebase 和 Google Cloud 产品(包括 Cloud Functions)的无缝集成。
Realtime Database
Firebase 实时数据库允许从客户端代码中直接安全地访问数据库,得益于此,您能够构建功能丰富的协作式应用。数据会永久性地保留在客户端,即使处于离线状态,实时事件仍会继续触发,给最终用户提供良好的即时性体验。当设备重新连接到网络时,实时数据库会将本地数据变化与客户端离线期间发生的远程更新同步,自动合并任何不一致的数据。
实时数据库提供灵活的基于表达式的规则语言(称为“Firebase 实时数据库安全规则”),可以定义您的数据结构以及何时可以读取或写入数据。当与 Firebase 身份验证集成时,开发者可以定义什么人可以访问什么数据以及如何访问数据。
实时数据库是一种 NoSQL 数据库,因此具有不同于关系型数据库的优化方向和功能特点。Realtime Database API 的设计只支持可以快速执行的操作。这使您能够构建实时性更强的体验,即使服务数百万的用户,响应速度也丝毫不受影响。因此,请务必认真考虑用户需要如何访问您的数据,以便相应地设计数据结构。
Stroage
Cloud Storage 可存储图像、视频和音频等文件,以及其他用户生成的内容。可以理解为 OSS
Hosting
Firebase 托管可托管您的网站的 HTML、CSS 和 JavaScript 资源以及由开发者提供的其他资源(如图形、字体和图标)。可以理解为虚拟主机
Plugins
插件模块主要是提供一些 应用程序中常用的功能,如 发送邮件、短信验证码等等
Functions
云函数,主要是执行一些需要后端处理的逻辑代码,托管在 Google 服务器,在您编写并部署函数后,Google 的服务器会立即开始管理函数。您可以使用 HTTP 请求直接触发函数,或者,如果触发的是后台函数,Google 的服务器会侦听事件并在函数被触发时运行函数。
Google 会随着负载的增加或减少而做出响应,迅速调节运行函数所需的虚拟服务器实例的数量。每个函数都拥有自己的配置,会在自己的环境中单独运行。
开发
实际开发过程中使用较多的是数据库和云函数模块,可以根据对应的开发文档引入 sdk,调用即可,官方文档
主要记录
国内开发者可能无法直接访问谷歌服务,配置 VPN 后,浏览器可以访问,通过 vs code 访问 firebase API 时会出现超时的问题,最可能出现在部署云函数时操作超时。
主要解决方法如下(适用于 nodejs 项目):
寻找 项目目录内 node_modules 下 @request/request.js 查找并替换如下代码片段
if (!self.hasOwnProperty('proxy')) {
//self.proxy = getProxyFromURI(self.uri)
self.proxy = '127.0.0.1:7890' // 端口号为你的代理端口,无需 http 前缀
}
安装完 firebase sdk 的 npm 包后,找到所在包的文件 node_modules\firebase-tools\lib\apiv2.js ,查找并替换如下内容
function proxyURIFromEnv() {
return 'http://127.0.0.1:7890' // 端口号为你的代理端口,需要携带 http 前缀
return (process.env.HTTPS_PROXY ||
process.env.https_proxy ||
process.env.HTTP_PROXY ||
process.env.http_proxy ||
undefined);
}
相关推荐
- Sublime Text 4 稳定版 Build 4113 发布
-
IT之家7月18日消息知名编辑器SublimeText4近日发布了Build4113版本,是SublimeText4的第二个稳定版。IT之家了解到,SublimeTe...
- 【小白课程】openKylin便签贴的设计与实现
-
openKylin便签贴作为侧边栏的一个小插件,提供便捷的文本记录和灵活的页面展示。openKylin便签贴分为两个部分:便签列表...
- 壹啦罐罐 Android 手机里的 Xposed 都装了啥
-
这是少数派推出的系列专题,叫做「我的手机里都装了啥」。这个系列将邀请到不同的玩家,从他们各自的角度介绍手机中最爱的或是日常使用最频繁的App。文章将以「每周一篇」的频率更新,内容范围会包括iOS、...
- 电气自动化专业词汇中英文对照表(电气自动化专业英语单词)
-
专业词汇中英文对照表...
- Python界面设计Tkinter模块的核心组件
-
我们使用一个模块,我们要熟悉这个模块的主要元件。如我们设计一个窗口,我们可以用Tk()来完成创建;一些交互元素,按钮、标签、编辑框用到控件;怎么去布局你的界面,我们可以用到pack()、grid()...
- 以色列发现“死海古卷”新残片(死海古卷是真的吗)
-
编译|陈家琦据艺术新闻网(artnews.com)报道,3月16日,以色列考古学家发现了死海古卷(DeadSeaScrolls)新残片。新出土的羊皮纸残片中包括以希腊文书写的《十二先知书》段落,这...
- 鸿蒙Next仓颉语言开发实战教程:订单列表
-
大家上午好,最近不断有友友反馈仓颉语言和ArkTs很像,所以要注意不要混淆。今天要分享的是仓颉语言开发商城应用的订单列表页。首先来分析一下这个页面,它分为三大部分,分别是导航栏、订单类型和订单列表部分...
- 哪些模块可以用在 Xposed for Lollipop 上?Xposed 模块兼容性解答
-
虽然已经有了XposedforLollipop的安装教程,但由于其还处在alpha阶段,一些Xposed模块能不能依赖其正常工作还未可知。为了解决大家对于模块兼容性的疑惑,笔者尽可能多...
- 利用 Fluid 自制 Mac 版 Overcast 应用
-
我喜爱收听播客,健身、上/下班途中,工作中,甚至是忙着做家务时。大多数情况下我会用MarcoArment开发的Overcast(Freemium)在iPhone上收听,这是我目前最喜爱的Po...
- 浅色Al云食堂APP代码(三)(手机云食堂)
-
以下是进一步优化完善后的浅色AI云食堂APP完整代码,新增了数据可视化、用户反馈、智能推荐等功能,并优化了代码结构和性能。项目结构...
- 实战PyQt5: 121-使用QImage实现一个看图应用
-
QImage简介QImage类提供了独立于硬件的图像表示形式,该图像表示形式可以直接访问像素数据,并且可以用作绘制设备。QImage是QPaintDevice子类,因此可以使用QPainter直接在图...
- 滚动条隐藏及美化(滚动条隐藏但是可以滚动)
-
1、滚动条隐藏背景/场景:在移动端,滑动的时候,会显示默认滚动条,如图1://隐藏代码:/*隐藏滚轮*/.ul-scrool-box::-webkit-scrollbar,.ul-scrool...
- 浅色AI云食堂APP完整代码(二)(ai 食堂)
-
以下是整合后的浅色AI云食堂APP完整代码,包含后端核心功能、前端界面以及优化增强功能。项目采用Django框架开发,支持库存管理、订单处理、财务管理等核心功能,并包含库存预警、数据导出、权限管理等增...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)
- vmware17pro最新密钥 (34)
- mysql单表最大数据量 (35)