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'这个值也要跟着变。

大概得设置就是这样~

相关推荐
hepherd11 小时前
Flutter - 原生交互 - 相机Camera - 曝光,缩放,录制视频
flutter·ios·dart
恋猫de小郭13 小时前
Flutter 应该如何实现 iOS 26 的 Liquid Glass ,它为什么很难?
android·前端·flutter
杉木笙13 小时前
Flutter 代码雨实现(矩阵雨)DLC 爆炸粒子
flutter·视觉设计
RichardLai8819 小时前
[Flutter 进阶] - Flutter 与原生通讯 - 你了解多少?
android·前端·flutter
恋猫de小郭21 小时前
React Native 0.80 开始支持 iOS 预构建
android·前端·flutter
张风捷特烈21 小时前
每日一题 Flutter#11 | StatelessWidget 从诞生到 build 的流程
android·flutter·面试
ZFJ_张福杰1 天前
【Flutter】Widget、Element和Render的关系-Flutter三棵树
flutter
vvilkim1 天前
Flutter JSON解析全攻略:使用json_serializable实现高效序列化
flutter·json
LinXunFeng1 天前
Flutter - GetX Helper 如何应用于旧页面
前端·flutter·开源
技术蔡蔡1 天前
从Google IO学习Flutter
flutter·google·google io