线上flutter 接口请求基本架构(线上实际项目搭建 很少讲直接上代码)android
首先添加库: pubspec.yaml 目录下:api
dio: ^2.1.2 #dio 请求框架
rxdart: ^0.21.0 #rx框架
复制代码
接口请求工具类:bash
class ApiDio {
static ApiDio instance;
static ApiService apiService;
ApiDio(){
var options = new BaseOptions(
connectTimeout: 5000,
receiveTimeout: 3000,
baseUrl:TTicarConfig.baseUrl,// api 头部例如 https://www.baidu.com
contentType: new ContentType('application', 'x-www-form-urlencoded',
charset: 'utf-8'));
Dio dio = new Dio(options);
dio.interceptors.add(AuthInterceptor());// 添加 token
dio..interceptors.add(LogInterceptor(responseBody: true, requestBody: true)); //添加日志
apiService= new ApiService(dio);
}
static ApiService getInstance() {
if (instance == null) {
instance = new ApiDio();
}
return _getApiService();
}
static ApiService _getApiService() {
return apiService;
}
}
/// AuthInterceptor
///
/// 添加header认证
class AuthInterceptor extends Interceptor {
String PLATFORM = "android";//可根据代码进行判断
String CLIENT = "store";
@override
onRequest(RequestOptions options) async{
Map<String, String> headers = new Map();
headers["Accept-Charset"] = "utf-8";
headers["Connection"] = "keep-alive";
headers["Accept"] = "*/*";
headers["x-version"] = TTicarConfig.VERSION_NAME;//本身更改配置
headers["x-platform"] = PLATFORM;
headers["x-client"] = CLIENT;
headers["x-equCode"] = TTicarConfig.equCode;//本身更改配置
headers["Authorization"] = TTicarConfig.TOKEN;//本身更改配置
options.headers=headers;
return super.onRequest(options);
}
}
复制代码
设置请求类型(post get 可本身添加想要的类型)网络
class ApiService {
ApiService(this.dio);
Dio dio;
//get请求结构
Future _get(String url, {Map<String, dynamic> params}) async {
var response = await dio.get(url, queryParameters: params);
return response.data;
}
//post
Future _post(String url, Map<String, dynamic> params) async {
var response = await dio.post(url, data: params);
return response.data;
}
Observable post(String url, Map<String, dynamic> params) =>
Observable.fromFuture(_post(url, params)).asBroadcastStream();
Observable get(String url, {Map<String, dynamic> params}) =>
Observable.fromFuture(_get(url, params: params)).asBroadcastStream();
}
复制代码
设置请求接口的工具类 (这不能够精简不须要或者经过注解的方式)架构
class TTicarWork {
/*
* 个人收藏商品列表
* */
Observable loadCollectGood(String pageNum, String pageSize) {
Map<String, String> map = new Map();
map["pageNum"] = pageNum;
map["pageSize"] = pageSize;
return ApiDio.getInstance().get("collection/good/list", params: map);
}
}
复制代码
请求接口app
new TTicarWork().loadCollectGood(pageNum, "20").listen((request) {
//接口请求成功 (request为map) 本身设置解析数据
}, onError: (e) {//请求异常等
});
复制代码
目前这个框架的缺陷 (若有更好的操做进行@我,我会逐渐修复)框架
1.没有经过注解的方式进行请求数据
2.没有自动解析数据
3.没有对网络进行判断(能够自行添加拦截器进行拦截判断)
复制代码