从零开始用flutter写一个完整应用⑸:网络请求
2022-06-16 本文已影响0人
逃离_102
说明
对一个移动端应用而言,网络请求是最基础功能之一,数据基本都是通过网络请求来获取。这2种是最常用的2种网络请求方式,所以我把它们归一起了。网络请求一般有2种一种是用原生的httpclient; 一种是第3方库http库或者dio库。
1,原生httpclient
导入dart:io,然后如下进行就可以了
import 'dart:io';
Future<Data> dioData(int page,int size) async {
final request = await HttpClient().getUrl(Uri.parse("https://api.apiopen.top/api/getHaoKanVideo?page=$page&size=$size"));
final response = await request.close();
if (response.statusCode == HttpStatus.ok) {
var json = await response.transform(utf8.decoder).join();
return Data.fromJson(jsonDecode(json));
} else {
// If the server did not return a 200 OK response,
// then throw an exception.
throw Exception('Failed to load Data');
}
}
当然网络请求少不了json解析,下面还会用到就一起放这了,这个属于复杂解析,基本满足所用情况了
// {
// "code": 200,
// "message": "成功!",
// "result": {
// "total": 11860,
// "list": [
// {
// "id": 7525,
// "title": "敢直接叫向华强要人,周润发当配角,给张学友做个表情包",
// "userName": "也毁灭另一些人",
// "userPic": "https://pic.rmb.bdstatic.com/bjh/user/00f938d6a2615985a2fe68b40252d319.jpeg?x-bce-process=image/resize,m_lfit,w_200,h_200&autime=33634",
// "coverUrl": "https://f7.baidu.com/it/u=4107050099,3096145322&fm=222&app=108&f=JPEG@s_2,w_681,h_381,q_100",
// "playUrl": "http://vd2.bdstatic.com/mda-nc5e6rphet3kr6td/cae_h264_delogo/1646561464607182321/mda-nc5e6rphet3kr6td.mp4",
// "duration": "01:19"
// },
// {
// "id": 10948,
// "title": "吕秀才倒霉的一天",
// "userName": "影视小滔",
// "userPic": "https://pic.rmb.bdstatic.com/bjh/user/ae482e23dfca594081b51d558d8367ac.jpeg?x-bce-process=image/resize,m_lfit,w_200,h_200&autime=37424",
// "coverUrl": "https://f7.baidu.com/it/u=3822864426,1054969009&fm=222&app=108&f=JPEG@s_2,w_681,h_381,q_100",
// "playUrl": "http://vd3.bdstatic.com/mda-ndg2vcdujbewdd9m/cae_h264_delogo/1650161723467982957/mda-ndg2vcdujbewdd9m.mp4",
// "duration": "05:21"
// }
// ]
// }
// }
class Data {
final int code;
final String message;
final Result result;
const Data({
required this.code,
required this.message,
required this.result,
});
factory Data.fromJson(Map<String, dynamic> json) {
return Data(
code: json['code'],
message: json['message'],
result: Result.fromJson(json['result']),
);
}
}
class Result {
final int total;
final List<ItemBean> list;
const Result({
required this.total,
required this.list,
});
factory Result.fromJson(Map<String, dynamic> json) {
var listT = json['list'] as List;
List<ItemBean> lists = listT.map((i) => ItemBean.fromJson(i)).toList();
return Result(
total: json['total'],
list: lists,
);
}
}
class ItemBean {
final int id;
final String title;
final String userName;
final String userPic;
final String coverUrl;
final String playUrl;
final String duration;
const ItemBean({
required this.id,
required this.title,
required this.userName,
required this.userPic,
required this.coverUrl,
required this.playUrl,
required this.duration,
});
factory ItemBean.fromJson(Map<String, dynamic> json) {
return ItemBean(
id: json['id'],
title: json['title'],
userName: json['userName'],
userPic: json['userPic'],
coverUrl: json['coverUrl'],
playUrl: json['playUrl'],
duration: json['duration'],
);
}
}
2,用http第3方库
加入依赖http: ^0.13.3;
导入import 'package:http/http.dart' as http;
分get,post,根据需求选择
Future<Data> fetchData(int page,int size) async {
final response = await http.get(Uri.parse('https://api.apiopen.top/api/getHaoKanVideo?page=$page&size=$size'));
if (response.statusCode == 200) {
// If the server did return a 200 OK response,
// then parse the JSON.
return Data.fromJson(jsonDecode(response.body));
} else {
// If the server did not return a 200 OK response,
// then throw an exception.
throw Exception('Failed to load Data');
}
}
Future<Data> fetchPostData(int page,int size) async {
//头部
var headers = Map<String, String>();
headers["Content-Type"] = "application/json";
//参数
Map params = {'page': '$page','size':'$size'};
// 嵌套两层都可以,但是具体哪个好还有待确认????
var jsonParams = utf8.encode(json.encode(params));
// var jsonParams = json.encode(params);
var httpClient = http.Client();
var uri = Uri.parse("https://api.apiopen.top/api/getHaoKanVideo");
final response = await httpClient.post(uri, body: jsonParams, headers: headers);
if (response.statusCode == 200) {
return Data.fromJson(jsonDecode(response.body));
} else {
throw Exception('Failed to load Data');
}
}
3,用dio第3方库
加入依赖dio : ^4.0.6;
导入import 'package:dio/dio.dart';
可get,post,下载,断点续传等功能,功能很强大,可根据需求,再仔细学习
Future<Data> dioData(int page,int size) async {
Dio dio = Dio();
final response = await dio.get("https://api.apiopen.top/api/getHaoKanVideo?page=$page&size=$size");
if (response.statusCode == 200) {
return Data.fromJson(response.data);
} else {
throw Exception('Failed to load Data');
}
}
Future<Data> dioPostData(int page,int size) async {
Dio dio = Dio();
//参数
Map params = {'page': '$page','size':'$size'};
final response = await dio.post("https://api.apiopen.top/api/getHaoKanVideo",data:params);
if (response.statusCode == 200) {
return Data.fromJson(response.data);
} else {
throw Exception('Failed to load Data');
}
}
demo
上主要是讲解了一些基本的用法,更详细的可参照demo
demo地址:https://github.com/liuyewu101/flutter_demo