Flutter Dio在 Charles等 抓包工具设置配置

前些天提测新业务,QA反馈Flutter 页面不能抓包,以前看数据信息都是通过log收集,没有单独通过抓包查看数据,对QA来说不能抓包确实是问题。查了一下发现Dio框架是默认不允许抓包的,需要额外配置抓包设置的相关代理。

所以想要Flutter 抓包需要配置代理的IP 地址和 端口号,可以通过用户在Flutter 输入然后配置到  DefaultHttpClientAdapter  中,也可以通过Native层代码获取设置的代理之后通过数据通信传递到Flutter,然后再进行配置:

1. 手动配置端口号:

先通过抓包工具查看IP 和端口号

然后在Flutter 页面传递到网络框架层进行配置

 

2.  代码获取抓包代理:

Android 抓包获取代理:

 @Override
    public void onMethodCall(@NonNull MethodCall methodCall, @NonNull io.flutter.plugin.common.MethodChannel.Result result) {
        switch (methodCall.method) {
            case "getProxy":
                String proxy = System.getProperty("http.proxyHost");
                String port = System.getProperty("http.proxyPort");
                Log.e("--------getProxy: ", proxy + " port: " + port);
                Map<String, Object> setting = new HashMap();
                setting.put("host", proxy);
                setting.put("port", port);
                result.success(setting);
                break;
        }
    }

 

iOS端获取代理信息

// iOS获取手机代理
- (void)syncProxy{
      //自动获取手机代理
       NSString * portalBaseUrlStr = @"http://www.baidu.com";
       NSDictionary *proxySettings = (__bridge NSDictionary *)(CFNetworkCopySystemProxySettings());
       NSArray *proxies = (__bridge NSArray *)(CFNetworkCopyProxiesForURL((__bridge CFURLRef _Nonnull)([NSURL URLWithString:portalBaseUrlStr]), (__bridge CFDictionaryRef _Nonnull)(proxySettings)));
       NSDictionary *settings = [proxies firstObject];
       NSString *hostName = [NSString stringWithFormat:@"%@",settings[@"kCFProxyHostNameKey"]];
       NSString *portName = [NSString stringWithFormat:@"%@",settings[@"kCFProxyPortNumberKey"]];
       //获取为空时居然是字符串"(null)"
       if ([hostName isEqualToString:@"(null)"]) {
           hostName = @"";
       }
       if ([portName isEqualToString:@"(null)"]) {
           portName = @"";
       }
    
}

 

Flutter层接收代理:

static Future getProxy() async {
    try {
      MethodChannel platform =
          MethodChannel(MethodChannelName.BASEINFO_CHANNEL);
      var setting = {};
      setting = await platform.invokeMethod("getProxy");
      Logger("----------getProxy:setting" + setting.toString());
      saveProxy(new Map<String, dynamic>.from(setting));
    } on Exception catch (e) {
      Logger("----------getProxy: e " + e.toString());
    }
  }
 ///保存代理
  static void saveProxy(Map<String, dynamic> setting) async {
    String proxyHost = setting['host'] ?? '';
    String proxyPort = setting['port'] ?? '';
   String  proxyHostAndPort  = 'PROXY ' + proxyHost + ':' + proxyPort;
    
  }

接收代理的方法调用在网络请求前就获取,获取完在网络请求时进行配置:

 

 static void setupProxy(Dio dio,String proxyHostAndPort) async {
    if (proxyHostAndPort != null && proxyHostAndPort.isNotEmpty) {
      (dio.httpClientAdapter as DefaultHttpClientAdapter).onHttpClientCreate =
          (client) {
        client.findProxy = (uri) {
          return proxyHostAndPort;
        };
        //忽略证书
        client.badCertificateCallback =
            (X509Certificate cert, String host, int port) => true;
      };
    }
  }

proxyHostAndPort 是包含IP地址和端口号的字符串,如果没有代理就不设置代理

 

保存后,重新打开APP,这个时候就可以在charles中查看到新发起的请求报文及响应报文了。

 

根据引用和引用,可以得出结论:在Flutter中使用Charles抓包工具无法捕获到HTTP请求数据包。原因是在手机上设置代理后,Charles无法正确抓取请求数据包。为了解决这个问题,可以通过自定义网络请求代理类来实现代理功能。首先,创建一个网络请求代理类`MyProxyHttpOverride`,继承`HttpOverrides`类,并重写`createHttpClient`方法,在该方法中设置代理地址。然后,在应用程序的入口处将全局的`HttpOverrides`对象设置为自定义的代理类。通过这样的设置,就可以使用代理来进行网络请求,但需要注意的是,设置代理可能会对安全性造成一定的威胁,需要谨慎使用。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [Flutter中http请求抓包的完美解决方案](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 ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值