Flutter中通过Charles无法抓包的问题解决

文章介绍了如何在Flutter项目中,使用dio库配置代理以配合Charles进行HTTP和HTTPS请求的抓包。关键步骤包括设置dio的httpClientAdapter,配置代理为本地Charles的端口8888,并通过client.badCertificateCallback忽略证书错误以解决抓包HTTPS请求时的证书问题。
摘要由CSDN通过智能技术生成

前提已经配置好Charles(代理、证书...)!

http请求库配置代理
 

dio配置代理
flutter项目里通常用dio库做http请求,我们可以通过dio的httpClientAdapter属性配置我们的本地代理。代码如下:

import 'package:dio/dio.dart';
​
var dio = Dio();
(dio.httpClientAdapter as DefaultHttpClientAdapter).onHttpClientCreate =(client) {
  client.findProxy = (uri) {
    return 'PROXY localhost:8888';};
  client.badCertificateCallback =
  (X509Certificate cert, String host, int port) => true; //忽略证书
}; 


其中client.findProxy函数用来返回我们的代理接口,charles的默认的系统代理端口是8888,所以这里配置成

PROXY localhost:8888就可以了。下面一句client.badCertificateCallback函数也很关键,如果不进行配置,charles在抓包https请求时会出现下图错误:


这个错误产生的原因,经我查阅网上资料是因为Flutter请求https时用的是自己的CA认证证书,所以charles在认证证书时没有通过,导致抓包错误。所以我们直接通过client.badCertificateCallback函数返回true来忽略证书就好了。

参考:Flutter配置代理抓包_flutter 代理_前端开发小陈的博客-CSDN博客

根据引用和引用,可以得出结论:在Flutter使用Charles抓包工具无法捕获到HTTP请求数据包。原因是在手机上设置代理后,Charles无法正确抓取请求数据包。为了解决这个问题,可以通过自定义网络请求代理类来实现代理功能。首先,创建一个网络请求代理类`MyProxyHttpOverride`,继承`HttpOverrides`类,并重写`createHttpClient`方法,在该方法设置代理地址。然后,在应用程序的入口处将全局的`HttpOverrides`对象设置为自定义的代理类。通过这样的设置,就可以使用代理来进行网络请求,但需要注意的是,设置代理可能会对安全性造成一定的威胁,需要谨慎使用。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [Flutterhttp请求抓包的完美解决方案](https://download.csdn.net/download/weixin_38654589/14029969)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [flutter 配置charles抓包](https://blog.csdn.net/lck8989/article/details/126940378)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值