每天一个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 数据,提取名言内容和作者信息。
- 异步操作处理: 使用
FutureBuilder
Widget 处理异步网络请求结果,构建动态 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...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...
Android Wi-Fi 连接失败日志分析
1. Android wifi 关键日志总结 (1) Wi-Fi 断开 (CTRL-EVENT-DISCONNECTED reason3) 日志相关部分: 06-05 10:48:40.987 943 943 I wpa_supplicant: wlan0: CTRL-EVENT-DISCONNECTED bssid44:9b:c1:57:a8:90 reason3 locally_generated1解析: CTR…...
线程同步:确保多线程程序的安全与高效!
全文目录: 开篇语前序前言第一部分:线程同步的概念与问题1.1 线程同步的概念1.2 线程同步的问题1.3 线程同步的解决方案 第二部分:synchronized关键字的使用2.1 使用 synchronized修饰方法2.2 使用 synchronized修饰代码块 第三部分ÿ…...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
数据链路层的主要功能是什么
数据链路层(OSI模型第2层)的核心功能是在相邻网络节点(如交换机、主机)间提供可靠的数据帧传输服务,主要职责包括: 🔑 核心功能详解: 帧封装与解封装 封装: 将网络层下发…...

分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...

算法笔记2
1.字符串拼接最好用StringBuilder,不用String 2.创建List<>类型的数组并创建内存 List arr[] new ArrayList[26]; Arrays.setAll(arr, i -> new ArrayList<>()); 3.去掉首尾空格...

Unsafe Fileupload篇补充-木马的详细教程与木马分享(中国蚁剑方式)
在之前的皮卡丘靶场第九期Unsafe Fileupload篇中我们学习了木马的原理并且学了一个简单的木马文件 本期内容是为了更好的为大家解释木马(服务器方面的)的原理,连接,以及各种木马及连接工具的分享 文件木马:https://w…...

【Linux】自动化构建-Make/Makefile
前言 上文我们讲到了Linux中的编译器gcc/g 【Linux】编译器gcc/g及其库的详细介绍-CSDN博客 本来我们将一个对于编译来说很重要的工具:make/makfile 1.背景 在一个工程中源文件不计其数,其按类型、功能、模块分别放在若干个目录中,mak…...
深入解析 ReentrantLock:原理、公平锁与非公平锁的较量
ReentrantLock 是 Java 中 java.util.concurrent.locks 包下的一个重要类,用于实现线程同步,支持可重入性,并且可以选择公平锁或非公平锁的实现方式。下面将详细介绍 ReentrantLock 的实现原理以及公平锁和非公平锁的区别。 ReentrantLock 实现原理 基本架构 ReentrantLo…...