flutter开发实战-请求dio设置Cookie

flutter开发实战-请求dio设置Cookie

在最近开发中碰到了需要websocket长链接收到响应的auth,在之后的请求中需要将其设置为cookie中。

如Cookie:auth=DHSfQQSAXf89xZqJTLdEDVI2hwzc7p2lUmSNNdUSlgW2MyfQIN+pYr7jUbkX/;

设置cookie用到了dio_cookie_manager组件

在pubspec.yaml引入dio_cookie_manager

复制代码
dio_cookie_manager: ^2.0.0 # latest version

2.1 使用CookieJar

复制代码
import 'package:cookie_jar/cookie_jar.dart';
import 'package:dio/dio.dart';
import 'package:dio_cookie_manager/dio_cookie_manager.dart';

void main() async {
  final dio = Dio();
  final cookieJar = CookieJar();
  dio.interceptors.add(CookieManager(cookieJar));
  // First request, and save cookies (CookieManager do it).
  await dio.get("https://dart.dev");
  // Print cookies
  print(await cookieJar.loadForRequest(Uri.parse("https://dart.dev")));
  // Second request with the cookies
  await dio.get('https://dart.dev');
}

CookieManager拦截器可以帮助我们自动管理请求/响应Cookie。

如果需要持久保存cookie,需要用到PersistCookieJar

复制代码
dio.interceptors.add(CookieManager(PersistCookieJar()))

2.1 使用PersistCookieJar

PersistCookieJar将cooke持久化保存。

在flutter中,传递给PersistCookieJar的路径必须有效(存在于具有写访问权限的手机中)。使用path_provider包可以获得正确的路径。

复制代码
Future<void> prepareJar() async {
  final Directory appDocDir = await getApplicationDocumentsDirectory();
  final String appDocPath = appDocDir.path;
  final jar = PersistCookieJar(
    ignoreExpires: true,
    storage: FileStorage(appDocPath + "/.cookies/"),
  );
  dio.interceptors.add(CookieManager(jar));
}
)

2.2 使用重定向请求处理Cookie

使用重定向请求处理Cookie重定向请求需要额外的配置才能正确解析cookie。需要将followRedirects设置为false。

允许Htto状态代码从300到399个预测为成功的响应。

使用HttpHeaders.locationHeader进行进一步请求。

复制代码
final cookieJar = CookieJar();
final dio = Dio()
  ..interceptors.add(CookieManager(cookieJar))
  ..options.followRedirects = false
  ..options.validateStatus =
      (status) => status != null && status >= 200 && status < 400;
final redirected = await dio.get('/redirection');
final response = await dio.get(
  redirected.headers.value(HttpHeaders.locationHeader)!,
);

2.2 将获取到的Auth设置到cookie中

将从长链接中获取到的Auth设置到cookie中

复制代码
 Future<void> setSaveCookie({
    required String name,
    required String value,
  }) async {
    Cookie cookie = Cookie(name, value);
    List<Cookie> cookies = [cookie];
    //Save cookies
    await jar.saveFromResponse(
        Uri.parse('https://ifour.cn'), cookies);
  }

调用setSaveCookie

复制代码
	// 收到消息,将cookie写入dio中
        String auth = "auth";
        String authValue = "${messageDo.data?.auth}";
        await SDHttp.getInstance().setSaveCookie(name: auth, value: authValue);

三、小结

flutter开发实战-请求dio设置Cookie。设置cookie用到了dio_cookie_manager组件。

学习记录,每天不停进步。

相关推荐
音浪豆豆_Rachel4 分钟前
Flutter 与原生通信的桥梁:深入解析 Pigeon 与后台线程通信
flutter·harmonyos
音浪豆豆_Rachel43 分钟前
Flutter跨平台通信的智能配置:Pigeon注解配置与鸿蒙生态深度集成
flutter·华为·harmonyos
Bryce李小白1 小时前
深入理解WidgetsFlutterBinding
flutter
云水木石1 小时前
Android 的下一个战场:Windows 应用与游戏?
android·windows·游戏
开心_开心急了1 小时前
Ai加Flutter实现自定义标题栏(appBar)
前端·flutter
雨声不在2 小时前
Android文字渐变的实现
android·textview
全栈派森2 小时前
Flutter 实战:基于 GetX + Obx 的企业级架构设计指南
前端·flutter
GoldenPlayer2 小时前
KTS语法
android
LorrestGump2 小时前
手游 iOS SDK 改用 CocoaPods 集成
ios
GoldenPlayer2 小时前
后台服务Service销毁逻辑+单例造成的内存泄露
android