Flutter笔记-Http网络请求基于

参考资料:https://blog.csdn.net/u011272795/article/details/82765544

1、安装dio

pubspec.yaml

dependencies:
  flutter:
    sdk: flutter
  dio: 1.0.9  #dio: x.x.x latest version(这个方式报错) 网络请求框架

2、请求工具类

/**
 *  网络请求工具类
 */
import 'package:dio/dio.dart';

class HttpUtil {
  static HttpUtil instance;
  Dio dio;
  Options options;

  /**
   *  创建单利
   */
  static HttpUtil getInstance() {
    if(instance == null){
      instance = new HttpUtil();
    }
    return instance;
  }

  HttpUtil(){
    options = Options(
        // 请求基地址
        baseUrl: "https://www.xx.com/api",
        //连接服务器超时时间,单位是毫秒.
        connectTimeout: 10000,
        ///  响应流上前后两次接受到数据的间隔,单位为毫秒。如果两次间隔超过[receiveTimeout],
        ///  [Dio] 将会抛出一个[DioErrorType.RECEIVE_TIMEOUT]的异常.
        ///  注意: 这并不是接收数据的总时限.
        receiveTimeout: 3000,
        headers: {},
    );
    dio = new Dio(options);
  }

  /**
   *  get
   */
  get(url, {data, options, cancelToken}) async {
    Response response;
    try{
      response = await dio.get(
        url, 
        data: data,
        cancelToken: cancelToken
      );
    } on DioError catch(e){
      if(CancelToken.isCancel(e)){
        print('get请求取消! ' + e.message);
      }
    }
    return response.data;
  }

  /**
   *  post
   */
  post(url, {data, options, cancelToken}) async {
    Response response;
    try{
      response = await dio.post(
          url,
          data: data,
          cancelToken: cancelToken
      );
    } on DioError catch(e){
      if(CancelToken.isCancel(e)){
        print('get请求取消! ' + e.message);
      }
    }
    return response.data;
  }

}


/**
 * 调用方式
 *  HttpUtil.getInstance().get
 *  HttpUtil().get
 */

3、调用方式

HttpUtil.getInstance().get(url, {data, options})
HttpUtil().get(url, {data, options})
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值