每天一个Flutter开发小项目 (8) : 掌握Flutter网络请求 - 构建每日名言应用
引言
欢迎再次回到 每天一个Flutter开发小项目 系列博客!在之前的七篇博客中,我们已经掌握了 Flutter UI 构建、状态管理、路由导航、表单处理,甚至数据持久化等一系列核心技能。您已经能够构建功能相对完善的本地应用。
然而,在互联网时代,绝大多数应用都需要与服务器进行数据交互,从远程 API 获取数据,才能展现更丰富的内容和更强大的功能。今天,我们将聚焦 Flutter 应用的 “网络连接” —— 网络请求,并构建一个充满智慧和启迪的 每日名言应用,让您掌握 Flutter 应用连接互联网、获取远程数据的专业技巧。
通过本篇博客,您将深入学习:
- Flutter 网络请求的核心概念: 理解 HTTP 协议,掌握 Flutter 中进行网络请求的基本流程和关键组件。
http插件的专业应用: 深入学习http插件,掌握在 Flutter 应用中使用http插件发送网络请求、接收响应、处理数据等全流程。- 异步网络请求的最佳实践: 理解 Flutter 中网络请求的异步特性,掌握
Future、async/await等异步编程技巧,确保应用流畅性和用户体验。 - JSON 数据解析: 学习如何解析从 API 接口返回的 JSON 数据,将 JSON 数据转换为 Dart 对象,方便在 Flutter 应用中使用。
- 每日名言应用的功能实现: 构建一个简洁优雅的每日名言应用,包括每日名言展示、加载动画、错误处理等核心功能。
- Flutter 应用联网能力的专业技能: 从网络请求发送到数据解析展示,全面提升 Flutter 应用联网能力的专业技能。
项目简介: 每日名言应用
我们的每日名言应用将围绕以下核心功能展开:
- 每日名言展示: 应用启动后,从远程 API 获取一句每日名言,并在应用界面上优雅展示名言内容和作者。
- 加载状态: 在网络请求过程中,显示加载动画,提升用户等待体验。
- 错误处理: 当网络请求失败或 API 接口返回错误时,应用能够友好地提示用户,并提供重试机制 (可选,本篇博客核心聚焦网络请求,重试机制可选实现)。
- 简洁优雅的UI: 应用界面设计简洁优雅,突出名言内容,提升用户阅读体验。
通过构建每日名言应用,我们将重点实践:
http插件集成: 在 Flutter 应用中集成http插件,搭建网络请求环境。- API 接口调用: 调用远程每日名言 API 接口,发送 HTTP GET 请求。
- JSON 数据解析: 解析 API 接口返回的 JSON 数据,提取名言内容和作者信息。
- 异步操作处理: 使用
FutureBuilderWidget 处理异步网络请求结果,构建动态 UI。 - Flutter 网络请求完整流程: 从网络请求发送到数据解析展示,完整实现 Flutter 网络请求的流程。
Flutter 网络请求核心概念详解
在开始构建每日名言应用之前,我们先来深入理解 Flutter 网络请求的核心概念,为后续的实战打牢理论基础。
-
HTTP 协议: 超文本传输协议 (Hypertext Transfer Protocol),是互联网上应用最广泛的网络协议之一,用于在客户端 (例如,Flutter 应用) 和服务器之间传输数据。 我们常用的网页浏览、API 接口调用等都基于 HTTP 协议。 HTTP 协议定义了客户端和服务器之间通信的请求 (Request) 和 响应 (Response) 格式。
-
HTTP 请求方法: HTTP 协议定义了多种请求方法,常用的有:
- GET: 获取资源,例如,从服务器获取数据,通常用于查询数据。 在每日名言应用中,我们将使用 GET 请求从 API 接口获取每日名言数据。
- POST: 提交数据,例如,向服务器提交表单数据、上传文件等,通常用于创建或更新数据。
- PUT: 更新资源,类似于 POST,但通常用于幂等性地更新资源 (多次请求结果相同)。
- DELETE: 删除资源,例如,删除服务器上的数据。
-
URL (统一资源定位符): 统一资源定位符 (Uniform Resource Locator),用于唯一标识互联网上的资源 (例如,网页、图片、API 接口等)。 URL 通常由协议、域名、路径、查询参数等组成。 例如,
https://api.example.com/quotes/daily就是一个 URL,指向一个 API 接口,用于获取每日名言数据。 -
JSON (JavaScript 对象表示法): JavaScript 对象表示法 (JavaScript Object Notation),是一种轻量级的数据交换格式,易于人阅读和编写,同时也易于机器解析和生成。 JSON 格式常用于 API 接口的数据返回格式。 在每日名言应用中,我们将接收 API 接口返回的 JSON 数据,并解析 JSON 数据,提取名言内容和作者信息。
-
http插件: Flutter 官方提供的 HTTP 客户端插件,用于在 Flutter 应用中发送 HTTP 请求、接收 HTTP 响应、处理 HTTP 头部、上传文件等。http插件提供了易于使用的 API,方便 Flutter 开发者进行网络编程。 -
异步编程 (Future, async/await): 网络请求通常是耗时的操作,为了避免阻塞 UI 线程,影响用户体验,Flutter 中的网络请求操作都是 异步 (Asynchronous) 的。 Flutter 使用
Future和async/await等关键字来处理异步操作。Future:Future代表一个异步操作的最终结果,可以理解为一个“未来的值”,该值在异步操作完成后才会返回。 网络请求方法通常返回一个Future对象,表示网络请求的响应结果将在未来某个时刻返回。async/await:async/await是 Dart 中用于简化异步编程的关键字。async关键字用于声明一个异步函数,await关键字用于等待一个Future对象完成,并获取Future对象的结果。 使用async/await可以使异步代码看起来更像同步代码,提高代码可读性。
实战步骤: 构建每日名言应用
接下来,我们将一步步使用 http 插件构建我们的每日名言应用。
步骤 1: 创建新的 Flutter 项目并添加 http 依赖
首先,创建一个新的 Flutter 项目,命名为 daily_quote_app。
然后在 pubspec.yaml 文件中添加 http 依赖:
dependencies:flutter:sdk: flutterhttp: ^0.13.0 # 使用最新版本,请查阅 pub.dev 获取最新版本号
运行 flutter pub get 命令获取依赖。
步骤 2: 选择每日名言 API 接口
我们需要选择一个提供每日名言 API 接口的网站。 网上有很多免费的每日名言 API 接口,例如:
- TheySaidSo Quote API:
https://quotes.rest/qod.json(需要注册获取 API Key,免费版有请求次数限制) - 公共免费API合集 (github 仓库):
https://github.com/public-apis/public-apis(可以在这个仓库中搜索 “quote” 关键词,找到其他免费的 quote API) - Inspirational Quotes API:
https://api.quotable.io/random(简单易用,无需 API Key,返回 JSON 数据) 本篇博客将使用 Inspirational Quotes API
我们将使用 Inspirational Quotes API,它的 API 接口 URL 为: https://api.quotable.io/random,访问该 URL 将返回一个 JSON 数据,包含一句随机的名言。
步骤 3: 定义名言数据模型 (Quote)
我们需要定义一个 Quote 类来表示名言数据,包含名言内容和作者信息。
创建 lib/models/quote.dart 文件,定义 Quote 类:
class Quote {final String content; // 名言内容final String author; // 名言作者const Quote({ // 使用 const 构造函数required this.content,required this.author,});factory Quote.fromJson(Map<String, dynamic> json) { // 工厂构造函数,从 JSON 数据创建 Quote 对象return Quote相关文章:
每天一个Flutter开发小项目 (8) : 掌握Flutter网络请求 - 构建每日名言应用
引言 欢迎再次回到 每天一个Flutter开发小项目 系列博客!在之前的七篇博客中,我们已经掌握了 Flutter UI 构建、状态管理、路由导航、表单处理,甚至数据持久化等一系列核心技能。您已经能够构建功能相对完善的本地应用。 然而,在互联网时代,绝大多数应用都需要与服务器进…...
C++Primer学习(4.8位运算符)
4.8位运算符 位运算符作用于整数类型的运算对象,并把运算对象看成是二进制位的集合。位运算符提供检查和设置二进制位的功能,如17.2节(第640页)将要介绍的,一种名为bitset的标准库类型也可以表示任意大小的二进制位集合,所以位运算符同样能用…...
在VSCode中使用MarsCode AI最新版本详解
如何在VSCode中使用MarsCode AI:最新版本详解与使用场景 在当今快速发展的软件开发领域,人工智能(AI)技术的应用已经变得越来越普遍。ByteDance推出的MarsCode AI是一款强大的AI编程助手,旨在帮助开发者更高效地编写代…...
可观测之Tracing-eBPF生态和发展
eBPF生态系统 eBPF已经不仅仅是一个内核技术,而是一个蓬勃发展的生态系统,涵盖了各种工具、库和项目,为可观测性、网络、安全等领域提供了强大的支持。 1. 核心工具与库 bcc (BPF Compiler Collection): 定位: 提供了更底层的e…...
linux 后台执行并输出日志
在Linux系统中,后台执行程序并输出日志通常有多种方法,这里列出几种常见的方法: 1. 使用&将命令放入后台 可以在命令的末尾加上&符号,将命令放入后台执行。例如: your_command > output.log 2>&1…...
C++ primer plus 第五节 循环
系列文章目录 C primer plus 第一节 步入C-CSDN博客 C primer plus 第二节 hello world刨析-CSDN博客 C primer plus 第三节 数据处理-CSDN博客 C primer plus 第四节 复合类型-CSDN博客 文章目录 系列文章目录 文章目录 前言 一 for循环 总结 前言 由于作者看了后面的内容&…...
使用Hydra进行AI项目的动态配置管理
引言:机器学习中的超参数调优挑战 在机器学习领域,超参数调优是决定模型性能的关键环节。不同的模型架构,如神经网络中的层数、节点数,决策树中的最大深度、最小样本分割数等;以及各种训练相关的超参数,像学习率、优化器类型、批量大小等,其取值的选择对最终模型的效果…...
.bash_profile一些笔记
下方ffmpeg目录为/Users/sin/Downloads/kakaaaaa/bin/ffmpeg 第一种方法冒号后拼接路径 第二种方法冒号后拼接变量 第三种方法,依旧用PATH变量拼接,更清晰美观而已 export的作用 权限问题: 确保 /Users/sin/Downloads/kaka/bin/ffmpeg 有可执行权限(通…...
数据虚拟化的中阶实践:从概念到实现
数据虚拟化的中阶实践:从概念到实现 在大数据时代,数据的数量、种类和来源呈现爆炸式增长,如何高效、灵活地访问和利用这些数据成为了企业面临的重要问题。数据虚拟化作为一种创新的技术,正逐渐成为解决这一难题的关键。它通过抽象化层将底层数据源与应用程序隔离,使得数…...
MongoDB安全管理
MongoDB如何鉴权 保证数据的安全性是数据库的重大职责之一。与大多数数据库一样,MongoDB内部提供了一套完整的权限防护机制。如下例所示: mongo --host 127.0.0.1 --port 27017 --username someone --password errorpass --authenticationDatabasestor…...
[STM32]从零开始的STM32 DEBUG问题讲解及解决办法
一、前言 最近也是重装了一次keil,想着也是重装了,也是去官网下载了一个5.41的最新版,在安装和配置编译器和别的版本keil都没太大的区别,但是在调试时,遇到问题了,在我Debug的System Viewer窗口中没有GPIO&…...
创建Order项目实现Clean Hexagonal架构
创建Order项目实现Clean & Hexagonal架构 前言 在上一节中,讲到了Clean & Hexagonal架构的理论部分,并且通过图形解释了从MVC架构到清洁架构到演变。下面我们通过创建项目的方式来进一步理解Clean & Hexagonal架构。 1.项目创建 1. 项目…...
【算法】图论 —— Floyd算法 python
洛谷 B3647 【模板】Floyd 题目描述 给出一张由 n n n 个点 m m m 条边组成的无向图。 求出所有点对 ( i , j ) (i,j) (i,j) 之间的最短路径。 输入格式 第一行为两个整数 n , m n,m n,m,分别代表点的个数和边的条数。 接下来 m m m 行,每行三…...
YOLOv5 + SE注意力机制:提升目标检测性能的实践
一、引言 目标检测是计算机视觉领域的一个重要任务,广泛应用于自动驾驶、安防监控、工业检测等领域。YOLOv5作为YOLO系列的最新版本,以其高效性和准确性在实际应用中表现出色。然而,随着应用场景的复杂化,传统的卷积神经网络在处…...
基于fast-whisper模型的语音识别工具的设计与实现
目录 摘 要 第1章 绪 论 1.1 论文研究主要内容 1.1.1模型类型选择 1.1.2开发语言的选择 1.2 国内外现状 第2章 关键技术介绍 2.1 关键性开发技术的介绍 2.1.1 Faster-Whisper数据模型 2.1.2 Django 第3章 系统分析 3.1 构架概述 3.1.1 功能构架 3.1.2 模块需求描述 3.2 系统开…...
python中单例模式应用
数据库连接池单例模式 1. 为什么使用单例模式 创建数据库连接是一个昂贵的过程(涉及网络通信、认证等)。单例模式的连接池可以在程序启动时初始化一组连接,并在整个生命周期中重用这些连接,而不是每次请求都新建连接。同时还可…...
鸿蒙HarmonyOS 开发简介
鸿蒙开发入门教程 一、技术简介 鸿蒙操作系统(HarmonyOS)是面向万物互联时代的全场景分布式操作系统,具备分布式软总线、分布式数据管理、分布式任务调度等核心能力,能让设备间实现无缝连接与协同,为用户提供统一、流…...
2. 在后端代码中加入日志记录模块
1. 说明 日志模块基本上是每一个软件系统开发中必不可少的,主要用于持久记录一些代码运行中的输出信息,辅助编码人员进行代码调试,以及后期软件上线运行报错分析。在Python中加入日志模块比较简单,只需要借助logging和RotatingFi…...
Linux软硬链接
目录 什么是软链接?软链接的特点软链接的原理什么是硬链接硬链接的特点硬链接的原理 什么是软链接? 在Linux操作系统中,文件系统的核心概念之一是链接,包括软链接(符号链接)和硬链接。这些链接提供了访问文…...
Kali换源
【刚忘了】 下面这个 里面的一删放就好了 deb http://mirrors.aliyun.com/kali kali-rolling main non-free contribdeb-src http://mirrors.aliyun.com/kali kali-rolling main non-free contrib...
eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)
说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...
生成xcframework
打包 XCFramework 的方法 XCFramework 是苹果推出的一种多平台二进制分发格式,可以包含多个架构和平台的代码。打包 XCFramework 通常用于分发库或框架。 使用 Xcode 命令行工具打包 通过 xcodebuild 命令可以打包 XCFramework。确保项目已经配置好需要支持的平台…...
解决Ubuntu22.04 VMware失败的问题 ubuntu入门之二十八
现象1 打开VMware失败 Ubuntu升级之后打开VMware上报需要安装vmmon和vmnet,点击确认后如下提示 最终上报fail 解决方法 内核升级导致,需要在新内核下重新下载编译安装 查看版本 $ vmware -v VMware Workstation 17.5.1 build-23298084$ lsb_release…...
Linux简单的操作
ls ls 查看当前目录 ll 查看详细内容 ls -a 查看所有的内容 ls --help 查看方法文档 pwd pwd 查看当前路径 cd cd 转路径 cd .. 转上一级路径 cd 名 转换路径 …...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...
华为云Flexus+DeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建
华为云FlexusDeepSeek征文|DeepSeek-V3/R1 商用服务开通全流程与本地部署搭建 前言 如今大模型其性能出色,华为云 ModelArts Studio_MaaS大模型即服务平台华为云内置了大模型,能助力我们轻松驾驭 DeepSeek-V3/R1,本文中将分享如何…...
根据万维钢·精英日课6的内容,使用AI(2025)可以参考以下方法:
根据万维钢精英日课6的内容,使用AI(2025)可以参考以下方法: 四个洞见 模型已经比人聪明:以ChatGPT o3为代表的AI非常强大,能运用高级理论解释道理、引用最新学术论文,生成对顶尖科学家都有用的…...
Android Bitmap治理全解析:从加载优化到泄漏防控的全生命周期管理
引言 Bitmap(位图)是Android应用内存占用的“头号杀手”。一张1080P(1920x1080)的图片以ARGB_8888格式加载时,内存占用高达8MB(192010804字节)。据统计,超过60%的应用OOM崩溃与Bitm…...
Device Mapper 机制
Device Mapper 机制详解 Device Mapper(简称 DM)是 Linux 内核中的一套通用块设备映射框架,为 LVM、加密磁盘、RAID 等提供底层支持。本文将详细介绍 Device Mapper 的原理、实现、内核配置、常用工具、操作测试流程,并配以详细的…...
Java线上CPU飙高问题排查全指南
一、引言 在Java应用的线上运行环境中,CPU飙高是一个常见且棘手的性能问题。当系统出现CPU飙高时,通常会导致应用响应缓慢,甚至服务不可用,严重影响用户体验和业务运行。因此,掌握一套科学有效的CPU飙高问题排查方法&…...
