如何使用 Dio 在 flutter 中调用 API?
How do calling API in flutter using Dio?
我需要解析 JSON 以反对并在我的应用程序中使用它,但我需要使用 dio 库来执行此操作,但我是新手,任何人都可以帮助我如何使用它来解析a JSON 到一个对象中,我的请求也需要一个令牌,我的对象将像这样锁定:
import 'dart:convert';
Users usersFromJson(String str) => Users.fromJson(json.decode(str));
String usersToJson(Users data) => json.encode(data.toJson());
class Users {
Users({
this.data,
});
List<Datum> data;
factory Users.fromJson(Map<String, dynamic> json) => Users(
data: List<Datum>.from(json["data"].map((x) => Datum.fromJson(x))),
);
Map<String, dynamic> toJson() => {
"data": List<dynamic>.from(data.map((x) => x.toJson())),
};
}
class Datum {
Datum({
this.id,
this.name,
this.email,
this.phone,
this.status,
this.images,
});
int id;
String name;
String email;
String phone;
String status;
List<Image> images;
factory Datum.fromJson(Map<String, dynamic> json) => Datum(
id: json["id"],
name: json["name"],
email: json["email"],
phone: json["phone"],
status: json["status"],
images: List<Image>.from(json["images"].map((x) => Image.fromJson(x))),
);
Map<String, dynamic> toJson() => {
"id": id,
"name": name,
"email": email,
"phone": phone,
"status": status,
"images": List<dynamic>.from(images.map((x) => x.toJson())),
};
}
class Image {
Image({
this.id,
this.url,
this.isProfileImage,
});
int id;
String url;
int isProfileImage;
factory Image.fromJson(Map<String, dynamic> json) => Image(
id: json["id"],
url: json["url"],
isProfileImage: json["is_profile_image"],
);
Map<String, dynamic> toJson() => {
"id": id,
"url": url,
"is_profile_image": isProfileImage,
};
}
任何人都可以使用提供程序和 dio 逐步帮助我完成此操作!
尝试这样的事情:
final client = Dio();
Future<_yourClass_> getData() async {
final url = 'your-url';
try {
final response = await client.get(url);
if (response.statusCode == 200) {
return _yourClass_.fromJson(response.data);
} else {
print('${response.statusCode} : ${response.data.toString()}');
throw response.statusCode;
}
} catch (error) {
print(error);
}
}
... _yourClass_ data = await getData();
如果你已经有一个令牌,你可以像这样将它添加到 dio 中:
Dio()..options.headers['authorization'] = 'Bearer $token';
当然要看权限类型。此外,如果您还没有令牌,则需要先发出请求以获取令牌(类似于上面所示),然后从 response.data.
获取令牌
这是一步一步的说明
首先创建一个dio API服务和服务工具class
import 'package:dio/dio.dart';
abstract class HttpService{
void init();
Future<Response> getRequest(String url);
}
一个Api调用工具class
import 'package:dio/dio.dart';
import 'package:getx_news_app_impl/service/http_service.dart';
const BASE_URL = "https://newsapi.org/";
const API_KEY = "fb12a31181aa4498ba52877978913275";
class HttpServiceImpl implements HttpService{
Dio _dio;
@override
Future<Response> getRequest(String url) async{
// TODO: implement getRequest
Response response;
try {
response = await _dio.get(url);
} on DioError catch (e) {
print(e.message);
throw Exception(e.message);
}
return response;
}
initializeInterceptors(){
_dio.interceptors.add(InterceptorsWrapper(
onError: (error){
print(error.message);
},
onRequest: (request){
print("${request.method} | ${request.path}");
},
onResponse: (response){
print("${response.statusCode} ${response.statusMessage} ${response.data}");
}
));
}
@override
void init() {
_dio = Dio(BaseOptions(
baseUrl: BASE_URL,
headers: {"Authorization" : "Bearer $API_KEY"}
));
initializeInterceptors();
}
}
然后使用那个 class 像这样调用 API
class NewsRepoImpl implements NewsRepo{
HttpService _httpService;
Future<List<Article>> getNewsHeadline() async{
// TODO: implement getNewsHeadline
try {
final response = await _httpService.getRequest("/v2/top-headlines?country=us");
final parsedResponse = NewsResponse.fromJson(response.data);
return parsedResponse.articles;
} on Exception catch (e) {
print(e);
return null;
}
}
}
import 'package:dio/dio.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
class ContactListWidget extends StatefulWidget {
const ContactListWidget({Key? key}) : super(key: key);
@override
_ContactListWidgetState createState() => _ContactListWidgetState();
}
class _ContactListWidgetState extends State<ContactListWidget> {
List<dynamic> users = [];
@override
void initState() {
super.initState();
getDio();
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(
child: ListView(
children: users.map((e) {
return Card(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
Expanded(
flex: 4,
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: const EdgeInsets.all(8.0),
child: CircleAvatar(
child: Image.network(e["avatar"]),
),
),
Flexible(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(e["name"],
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
)),
Text(e["title"],maxLines: 1,overflow: TextOverflow.ellipsis,),
Chip(label: Text(e["role"]),),
],
),
),
),
],
),
),
Expanded(
flex: 1,
child: Text(
'$ ${e["balance"].toString() == "null" ? "0" : e["balance"].toString()}',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
),
),
],
),
),
);
}).toList(),
),
),
);
}
void getDio() async {
try {
var response = await Dio(BaseOptions(headers: {"Content-Type":
"application/json"}))
.get('https://mock-database-f1298.web.app/api/v1/users');
users = response.data["users"];
setState(() {});
} catch (e) {
print(e);
}
}
}
Sample Image
<img src="https://i.stack.imgur.com/OvIOH.png">
我需要解析 JSON 以反对并在我的应用程序中使用它,但我需要使用 dio 库来执行此操作,但我是新手,任何人都可以帮助我如何使用它来解析a JSON 到一个对象中,我的请求也需要一个令牌,我的对象将像这样锁定:
import 'dart:convert';
Users usersFromJson(String str) => Users.fromJson(json.decode(str));
String usersToJson(Users data) => json.encode(data.toJson());
class Users {
Users({
this.data,
});
List<Datum> data;
factory Users.fromJson(Map<String, dynamic> json) => Users(
data: List<Datum>.from(json["data"].map((x) => Datum.fromJson(x))),
);
Map<String, dynamic> toJson() => {
"data": List<dynamic>.from(data.map((x) => x.toJson())),
};
}
class Datum {
Datum({
this.id,
this.name,
this.email,
this.phone,
this.status,
this.images,
});
int id;
String name;
String email;
String phone;
String status;
List<Image> images;
factory Datum.fromJson(Map<String, dynamic> json) => Datum(
id: json["id"],
name: json["name"],
email: json["email"],
phone: json["phone"],
status: json["status"],
images: List<Image>.from(json["images"].map((x) => Image.fromJson(x))),
);
Map<String, dynamic> toJson() => {
"id": id,
"name": name,
"email": email,
"phone": phone,
"status": status,
"images": List<dynamic>.from(images.map((x) => x.toJson())),
};
}
class Image {
Image({
this.id,
this.url,
this.isProfileImage,
});
int id;
String url;
int isProfileImage;
factory Image.fromJson(Map<String, dynamic> json) => Image(
id: json["id"],
url: json["url"],
isProfileImage: json["is_profile_image"],
);
Map<String, dynamic> toJson() => {
"id": id,
"url": url,
"is_profile_image": isProfileImage,
};
}
任何人都可以使用提供程序和 dio 逐步帮助我完成此操作!
尝试这样的事情:
final client = Dio();
Future<_yourClass_> getData() async {
final url = 'your-url';
try {
final response = await client.get(url);
if (response.statusCode == 200) {
return _yourClass_.fromJson(response.data);
} else {
print('${response.statusCode} : ${response.data.toString()}');
throw response.statusCode;
}
} catch (error) {
print(error);
}
}
... _yourClass_ data = await getData();
如果你已经有一个令牌,你可以像这样将它添加到 dio 中:
Dio()..options.headers['authorization'] = 'Bearer $token';
当然要看权限类型。此外,如果您还没有令牌,则需要先发出请求以获取令牌(类似于上面所示),然后从 response.data.
获取令牌这是一步一步的说明
首先创建一个dio API服务和服务工具class
import 'package:dio/dio.dart';
abstract class HttpService{
void init();
Future<Response> getRequest(String url);
}
一个Api调用工具class
import 'package:dio/dio.dart';
import 'package:getx_news_app_impl/service/http_service.dart';
const BASE_URL = "https://newsapi.org/";
const API_KEY = "fb12a31181aa4498ba52877978913275";
class HttpServiceImpl implements HttpService{
Dio _dio;
@override
Future<Response> getRequest(String url) async{
// TODO: implement getRequest
Response response;
try {
response = await _dio.get(url);
} on DioError catch (e) {
print(e.message);
throw Exception(e.message);
}
return response;
}
initializeInterceptors(){
_dio.interceptors.add(InterceptorsWrapper(
onError: (error){
print(error.message);
},
onRequest: (request){
print("${request.method} | ${request.path}");
},
onResponse: (response){
print("${response.statusCode} ${response.statusMessage} ${response.data}");
}
));
}
@override
void init() {
_dio = Dio(BaseOptions(
baseUrl: BASE_URL,
headers: {"Authorization" : "Bearer $API_KEY"}
));
initializeInterceptors();
}
}
然后使用那个 class 像这样调用 API
class NewsRepoImpl implements NewsRepo{
HttpService _httpService;
Future<List<Article>> getNewsHeadline() async{
// TODO: implement getNewsHeadline
try {
final response = await _httpService.getRequest("/v2/top-headlines?country=us");
final parsedResponse = NewsResponse.fromJson(response.data);
return parsedResponse.articles;
} on Exception catch (e) {
print(e);
return null;
}
}
}
import 'package:dio/dio.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
class ContactListWidget extends StatefulWidget {
const ContactListWidget({Key? key}) : super(key: key);
@override
_ContactListWidgetState createState() => _ContactListWidgetState();
}
class _ContactListWidgetState extends State<ContactListWidget> {
List<dynamic> users = [];
@override
void initState() {
super.initState();
getDio();
}
@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(
child: ListView(
children: users.map((e) {
return Card(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: [
Expanded(
flex: 4,
child: Row(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Padding(
padding: const EdgeInsets.all(8.0),
child: CircleAvatar(
child: Image.network(e["avatar"]),
),
),
Flexible(
child: Padding(
padding: const EdgeInsets.all(8.0),
child: Column(
crossAxisAlignment: CrossAxisAlignment.start,
children: [
Text(e["name"],
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
)),
Text(e["title"],maxLines: 1,overflow: TextOverflow.ellipsis,),
Chip(label: Text(e["role"]),),
],
),
),
),
],
),
),
Expanded(
flex: 1,
child: Text(
'$ ${e["balance"].toString() == "null" ? "0" : e["balance"].toString()}',
style: TextStyle(
fontWeight: FontWeight.bold,
fontSize: 20,
),
),
),
],
),
),
);
}).toList(),
),
),
);
}
void getDio() async {
try {
var response = await Dio(BaseOptions(headers: {"Content-Type":
"application/json"}))
.get('https://mock-database-f1298.web.app/api/v1/users');
users = response.data["users"];
setState(() {});
} catch (e) {
print(e);
}
}
}
Sample Image
<img src="https://i.stack.imgur.com/OvIOH.png">