欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

详解flutter之网络请求dio,请求,拦截器简单示例

程序员文章站 2022-07-19 20:16:49
flutter一直很火的网络请求插件dio 直接上代码,写成一个类,可以直接使用 包含请求的封装,拦截器的封装 import 'package:dio...

flutter一直很火的网络请求插件dio

直接上代码,写成一个类,可以直接使用

包含请求的封装,拦截器的封装

import 'package:dio/dio.dart';
import 'dart:async';
import 'dart:io';
import './apidomain.dart';
import './httpheaders.dart';
import 'package:shared_preferences/shared_preferences.dart';
class dioutil{
  static dio dio = new dio();
  //请求部分
  static future request(url,{formdata})async{
    try{
      response response;
      dio.options.headers = httpheaders;
      dio.options.contenttype = contenttype.parse("application/json;charset=utf-8");
      if(formdata == null){
        response = await dio.post(serviceurl+url);
      }else{
        response = await dio.post(serviceurl+url,data:formdata);
      }
      if(response.statuscode == 200){
        return response;
      }else{
        throw exception("接口异常r");
      }
    }catch(e){
      print("网络出现错误${e}");
    }
  }
  //拦截器部分
  static tokeninter(){
    dio.interceptors.add(interceptorswrapper(
      onrequest:(requestoptions options){
        // 在发送请求之前做一些预处理
        //我这边是在发送前到sharedpreferences(本地存储)中取出token的值,然后添加到请求头中
        //dio.lock()是先锁定请求不发送出去,当整个取值添加到请求头后再dio.unlock()解锁发送出去
        dio.lock();
        future<dynamic> future = future(()async{
          sharedpreferences prefs =await sharedpreferences.getinstance();
          return prefs.getstring("logintoken");
        });
        return future.then((value) {
          options.headers["authorization"] = value;
          return options;
        }).whencomplete(() => dio.unlock()); // unlock the dio
      },
      onresponse:(response response) {
        // 在返回响应数据之前做一些预处理
        return response; // continue
      },
      onerror: (dioerror e) {
        // 当请求失败时做一些预处理
        return e;//continue
      }
    ));
  }
}

httpheaders文件则是放一些请求头信息如下

const httpheaders={
  'accept': 'application/json, text/plain, */*',
  'authorization': '666',
  'content-type': 'application/json;charset=utf-8',
  'origin': 'http://localhost:8080',
  'referer': 'http://localhost:8080/',
  'user-agent': 'mozilla/5.0 (windows nt 10.0; win64; x64) applewebkit/537.36 (khtml, like gecko) chrome/73.0.3683.103 safari/537.36',
};

apidomain文件则是放api的地址信息如下

const serviceurl = 'http://39.xxx.xxx.xx:8080';

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。