Flutter中http请求抓包的解决方案

本文深入探讨了在Flutter中如何解决HTTP请求抓包的问题,详细分析了http.dart和http_impl.dart源码,揭示了代理配置的重要性,并提供了示例代码及替代抓包方案。
这篇文章主要给大家介绍了关于Flutter中http请求抓包的完美解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者使用Flutter具有一定的参考学习价值。

前言
前阵子有同学反馈Flutter中的http请求无法通过fiddler抓包,作者喜欢使用Charles抓包工具,于是抽时间写了个小demo测试了一下,结论是在手机上设置代理,Charles确实抓不到请求数据包。于是对该问题进行了分析:

确定使用的是http发起的get请求,理论上http协议应该可以被Charles抓到包的,如果没有抓到包,那可能是没有走代理,于是乎通过将笔记本连接的wifi断开测试了一下手机上APP发起http请求,发现请求成功,证实确实没有走代理;
为什么http请求没有通过wifi走代理呢,因为之前安卓原生使用的一些http框架都是正常走代理的啊,那是不是有可能代码中有api方法可以设置请求不走代理,于是乎就研读了一下Flutter中http相关的源码,最终找到了答案。
http请求源码跟踪
http.dart中的HttpClient是一个抽象类,成员方法的具体实现在http_impl.dart中,http的get请求实现如下:

Future<HttpClientRequest> getUrl(Uri url) => _openUrl("get", url);
 
Future<_HttpClientRequest> _openUrl(String method, Uri uri) {
   
   
.
.
.
// Check to see if a proxy server should be used for this connection.
var proxyConf = const _ProxyConfiguration.direct();
if (_findProxy != null) {
   
   
// TODO(sgjesse): Keep a map of these as normally only a few
// configuration strings will be used.
try {
   
   
proxyConf = new _ProxyConfiguration(_findProxy(uri));
} catch (error, stackTrace) {
   
   
return new Future.error(error, stackTrace);
}
}
return _getConnection(uri.host, port, proxyConf, isSecure)
.then((_ConnectionInfo info) {
   
   
.
.
.
});
}

首先,我们可以发现方法中有一行注释// Check to see if a proxy server should be used for this connection.,意思是“检查是否应该使用代理服务器进行此连接”;
然后,有一个proxyConf对象初始化和根据_findProxy来创建新的proxyConf对象的语句,然后通过_getConnection(uri.host, port, proxyConf, isSecure)来创建连接,_getConnection的源码如下:

Future<_ConnectionInfo> _getConnection(String uriHost, int uriPort,
_ProxyConfiguration proxyConf, bool isSecure) {
   
   
Iterator<_Proxy> proxies = proxyConf.proxies.iterator;
 
Future<_ConnectionInfo> connect(error) {
   
   
if (!proxies.<
Flutter中,可以使用三种主要的方式进行HTTP请求:io.dart里的HttpClient实现、Dart原生http请求库实现以及第三方库实现。 io.dart里的HttpClient实现是Flutter中最底层的HTTP请求方式,它提供了较低级别的API,可以用于创建和发送HTTP请求。Dart原生http请求库也是一种常用的HTTP请求方式,它提供了更高级别的API,可以更方便地发送HTTP请求和处理响应。第三方库则是Flutter社区中其他开发者编写的库,它们通常提供了更多的功能和便捷的API,可以更加简化和加速开发过程。根据具体的需求和项目的规模,选择合适的方式进行HTTP请求是很重要的。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Flutterhttp请求抓包的完美解决方案](https://download.youkuaiyun.com/download/weixin_38732307/12750709)[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_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [Flutter Http网络请求详解](https://blog.youkuaiyun.com/jay100500/article/details/88386470)[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_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值