Flutter_学习记录_iOS 模拟器用Charles抓包

参考文章:
Flutter 使用Charles软件抓包

1. 前言

Flutter应用网络请求调试一直是业内难题,原因在于Dart语言标准库的网络请求不会走Wi-Fi代理,常规通过配置Wi-Fi代理来抓包的方式行不通。这给我们日常开发测试造成了很大的阻碍,严重降低工作效率。

2. 抓包解决方案

2.1 安装抓包工具Charles

请参考这个文章:charlse抓包和Mock数据

2.2 模拟器设置代理

首先,设置Charles允许抓包电脑数据,如下图设置:

其次,安装模拟器证书,如下图:

第三,打开模拟器的safari, 输入http://chls.pro/ssl, 安装证书,然后在模拟器的设置->通用->关于本机->证书信任设置,打开Charles的证书信任:

2.3 代码设置代理

通过如下步骤,查看本地网络的代理端口:

记住这个数据:

在代码中配置网络转发的端口, 我是在第一次网络请求的页面中配置的,代码如下:

dart 复制代码
import 'package:flutter/material.dart';
// 网络请求
import 'package:dio/dio.dart';
import 'package:dio/io.dart';

class HomePage extends StatefulWidget {
  const HomePage({super.key});

  @override
  State<HomePage> createState() => _HomePageState();
}

class _HomePageState extends State<HomePage> {

  final dio = Dio();
  
  @override
  void initState() {
    super.initState();

    // TODO: --设置代理的地方,等待删除
     (dio.httpClientAdapter as DefaultHttpClientAdapter).onHttpClientCreate = (client) { 
          client.findProxy = (uri) {
            return 'PROXY 192.168.1.4:8888';
          };
     };
    // 获取轮播图的数据
    _getSwipterDataRequest();
    // 获取猜你喜欢的数据
    _getGuessYouLikeDataRequest();
  }
}

2.4代码解读

其中发挥作用的是,这几句代码:

dart 复制代码
final dio = Dio();
    // TODO: --设置代理的地方,等待删除
     (dio.httpClientAdapter as DefaultHttpClientAdapter).onHttpClientCreate = (client) { 
          client.findProxy = (uri) {
            return 'PROXY 192.168.1.4:8888';
          };
     };

其中192.168.1.4:8888 这个值是步骤2.3 让记住的端口, 同时也说明了:再次启动charles时,如果charles的端口变了,代码的设置的'PROXY 192.168.1.4:8888'这个值也要跟着变。

大概得设置就是这样~

相关推荐
里欧跑得慢1 小时前
12. CSS滤镜效果详解:为页面注入艺术灵魂
前端·css·flutter·web
里欧跑得慢1 小时前
CSS 级联层:控制样式优先级的新方式
前端·css·flutter·web
恋猫de小郭3 小时前
Jetpack Compose 1.11 正式版发布,下一代的全新控件和样式 API,你必须知道
android·前端·flutter
IntMainJhy3 小时前
Flutter 三方库 ImagePicker 的鸿蒙化适配与实战指南(相机/相册/多图选择全实现)
数码相机·flutter·harmonyos
IntMainJhy4 小时前
Flutter 三方库 SecureStorage 加密存储鸿蒙化适配与实战指南(加密读写+批量操作全覆盖)
flutter·华为·harmonyos
2301_814809864 小时前
实战分享Flutter Web 开发:解决跨域(CORS)问题的终极指南
前端·flutter
程序员老刘19 小时前
为什么满帧运行的游戏,玩起来反而觉得卡顿?
flutter·客户端
猫山月19 小时前
Flutter路由演进路线(2026)
前端·flutter
悟空瞎说1 天前
Flutter热更新 Shorebird CodePush 原理、实现细节及费用说明
前端·flutter
Lanren的编程日记1 天前
Flutter 鸿蒙应用AR功能集成实战:多平台AR框架+模拟模式,打造增强现实体验
flutter·ar·harmonyos