日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

设置datalist 中option的宽度_Flutter中http请求抓包的完美解决方案

發(fā)布時間:2025/3/15 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 设置datalist 中option的宽度_Flutter中http请求抓包的完美解决方案 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

前言

前陣子有同學(xué)反饋Flutter中的http請求無法通過fiddler抓包,作者喜歡使用Charles抓包工具,于是抽時間寫了個小demo測試了一下,結(jié)論是在手機上設(shè)置代理,Charles確實抓不到請求數(shù)據(jù)包。于是對該問題進行了分析:

  • 確定使用的是http發(fā)起的get請求,理論上http協(xié)議應(yīng)該可以被Charles抓到包的,如果沒有抓到包,那可能是沒有走代理,于是乎通過將筆記本連接的wifi斷開測試了一下手機上APP發(fā)起http請求,發(fā)現(xiàn)請求成功,證實確實沒有走代理;
  • 為什么http請求沒有通過wifi走代理呢,因為之前安卓原生使用的一些http框架都是正常走代理的啊,那是不是有可能代碼中有api方法可以設(shè)置請求不走代理,于是乎就研讀了一下Flutter中http相關(guān)的源碼,最終找到了答案。

http請求源碼跟蹤

http.dart中的HttpClient是一個抽象類,成員方法的具體實現(xiàn)在http_impl.dart中,http的get請求實現(xiàn)如下:

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) {...}); }

首先,我們可以發(fā)現(xiàn)方法中有一行注釋// Check to see if a proxy server should be used for this connection.,意思是“檢查是否應(yīng)該使用代理服務(wù)器進行此連接”;

然后,有一個proxyConf對象初始化和根據(jù)_findProxy來創(chuàng)建新的proxyConf對象的語句,然后通過_getConnection(uri.host, port, proxyConf, isSecure)來創(chuàng)建連接,_getConnection的源碼如下:

Future<_ConnectionInfo> _getConnection(String uriHost, int uriPort,_ProxyConfiguration proxyConf, bool isSecure) {Iterator<_Proxy> proxies = proxyConf.proxies.iterator;Future<_ConnectionInfo> connect(error) {if (!proxies.moveNext()) return new Future.error(error);_Proxy proxy = proxies.current;String host = proxy.isDirect ? uriHost : proxy.host;int port = proxy.isDirect ? uriPort : proxy.port;return _getConnectionTarget(host, port, isSecure).connect(uriHost, uriPort, proxy, this)// On error, continue with next proxy..catchError(connect);}return connect(new HttpException("No proxies given")); }

從代碼中我們可以看到根據(jù)代理配置信息來將請求的host和port進行重置,然后創(chuàng)建真實的連接。

跟蹤以上源碼我們發(fā)現(xiàn)dart中http請求是否走代理是需要配置的,而_findProxy變量和配置的代理信息有關(guān)。

http__impl.dart文件中的_HttpClient類中定義了_findProxy的默認值

Function _findProxy = HttpClient.findProxyFromEnvironment;

HttpClient類中findProxyFromEnvironment方法的實現(xiàn)

static String findProxyFromEnvironment(Uri url,{Map<String, String> environment}) {HttpOverrides overrides = HttpOverrides.current;if (overrides == null) {return _HttpClient._findProxyFromEnvironment(url, environment);}return overrides.findProxyFromEnvironment(url, environment); }

_HttpClient類中_findProxyFromEnvironment方法的實現(xiàn)

static String _findProxyFromEnvironment(Uri url, Map<String, String> environment) {checkNoProxy(String option) {if (option == null) return null;Iterator<String> names = option.split(",").map((s) => s.trim()).iterator;while (names.moveNext()) {var name = names.current;if ((name.startsWith("[") &&name.endsWith("]") &&"[${url.host}]" == name) ||(name.isNotEmpty && url.host.endsWith(name))) {return "DIRECT";}}return null;}checkProxy(String option) {if (option == null) return null;option = option.trim();if (option.isEmpty) return null;int pos = option.indexOf("://");if (pos >= 0) {option = option.substring(pos + 3);}pos = option.indexOf("/");if (pos >= 0) {option = option.substring(0, pos);}// Add default port if no port configured.if (option.indexOf("[") == 0) {var pos = option.lastIndexOf(":");if (option.indexOf("]") > pos) option = "$option:1080";} else {if (option.indexOf(":") == -1) option = "$option:1080";}return "PROXY $option";}// Default to using the process current environment.if (environment == null) environment = _platformEnvironmentCache;String proxyCfg;String noProxy = environment["no_proxy"];if (noProxy == null) noProxy = environment["NO_PROXY"];if ((proxyCfg = checkNoProxy(noProxy)) != null) {return proxyCfg;}if (url.scheme == "http") {String proxy = environment["http_proxy"];if (proxy == null) proxy = environment["HTTP_PROXY"];if ((proxyCfg = checkProxy(proxy)) != null) {return proxyCfg;}} else if (url.scheme == "https") {String proxy = environment["https_proxy"];if (proxy == null) proxy = environment["HTTPS_PROXY"];if ((proxyCfg = checkProxy(proxy)) != null) {return proxyCfg;}}return "DIRECT"; }

從以上代碼中可以發(fā)現(xiàn)代理配置從environment中讀取,設(shè)置代理時必須指定http_proxy或https_proxy等。而從_openUrl方法實現(xiàn)中proxyConf = new _ProxyConfiguration(_findProxy(uri));得出默認情況下environment是為空的,所以要想在Flutter的http請求中使用代理,則要指定相應(yīng)的代理配置,即設(shè)置httpClient.findProxy的值。

示例代碼:

_getHttpData() async {var httpClient = new HttpClient();httpClient.findProxy = (url) {return HttpClient.findProxyFromEnvironment(url, environment: {"http_proxy": 'http://192.168.124.7:8888',});};var uri =new Uri.http('t.weather.sojson.com', '/api/weather/city/101210101');var request = await httpClient.getUrl(uri);var response = await request.close();if (response.statusCode == 200) {print('請求成功');var responseBody = await response.transform(Utf8Decoder()).join();print('responseBody = $responseBody');} else {print('請求失敗');} }

以上代碼設(shè)置后即可使用Fiddler或Charles抓包了。

注:

  • 代碼中已設(shè)置代理,手機wifi不再需要進行代理設(shè)置;
  • 192.168.124.7該IP為我們需要抓包的Charles所在電腦IP;

第二種抓包解決方案

如果使用Flutter寫的APP不手動設(shè)置代理,則可以使用另一種方案來抓包。

通過電腦設(shè)置熱點 -> 使用手機連接電腦熱點上網(wǎng) -> 在電腦上使用Wireshark抓數(shù)據(jù)包。

具體步驟如下(macOS系統(tǒng)下):

1. 打開系統(tǒng)偏好設(shè)置,找到“共享”

2. 打開“共享”,顯示以下窗口,并選擇共享以下來源的連接為指定的有線網(wǎng)絡(luò),用以下端口共享給電腦選擇為Wi-Fi

3. 點擊右下角Wi-Fi選項按鈕,顯示如下,填寫對應(yīng)信息后點擊“好”保存

4. 回到剛才的“共享”窗口,打開左側(cè)窗口中的服務(wù)“互聯(lián)網(wǎng)共享”

5. 然后打開Wireshark軟件界面,首頁選擇對應(yīng)開熱點的網(wǎng)絡(luò)雙擊

6. 請求接口域名http://t.weather.sojson.com對應(yīng)的IP為 58.222.18.24,則在上面輸入框中輸入請求過濾條件 "ip.dst == 58.222.18.24",然后通過手機APP發(fā)起網(wǎng)絡(luò)請求

查看接口的IP地址

1
2
3
4
5$ ping t.weather.sojson.comPING nm.ctn.aicdn.com (58.222.18.24): 56 data bytes64 bytes from 58.222.18.24: icmp_seq=0 ttl=54 time=16.792 ms64 bytes from 58.222.18.24: icmp_seq=1 ttl=54 time=16.926 ms64 bytes from 58.222.18.24: icmp_seq=2 ttl=54 time=15.804 ms

7. 選擇對應(yīng)的http請求,箭頭指定行,右鍵點擊,選擇Follow->HTTP Stream選項

8. 彈出具體網(wǎng)絡(luò)請求信息窗口如下

總結(jié)

以上是生活随笔為你收集整理的设置datalist 中option的宽度_Flutter中http请求抓包的完美解决方案的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 精品国产18久久久久久 | 日韩中文字幕一区二区 | 国产精品久久久久久久久久东京 | 台湾男男gay做爽爽的视频 | 亚洲无码精品在线播放 | 污片免费在线观看 | 日韩电影观看 | 玩弄白嫩少妇xxxxx性 | 韩国三级视频在线 | 91麻豆精品国产91久久久久久 | 欧亚av在线 | 亚洲精品乱码久久久久久蜜桃麻豆 | 日韩精品一区二区三区久久 | 美女啪啪免费视频 | 久久国产精品区 | 一级少妇毛片 | 美女午夜激情 | 色婷婷婷婷 | 在线中文字日产幕 | 国产又粗又长又黄视频 | 欧美日一本 | xvideos成人免费视频 | 九九精品在线播放 | 成人黄色在线免费观看 | 2025韩国大尺度电影 | 偷拍亚洲视频 | 久操热久操 | 美女久久久久久久久久 | 久久激情影院 | 三级精品在线观看 | 公肉吊粗大爽色翁浪妇视频 | 欧美日韩在线视频免费播放 | 黄色片网站视频 | 三级网站视频 | 另类一区| 狠狠干导航 | 欧美在线性 | 亚州黄色 | 国产精品 欧美激情 | 亚洲欧美日韩第一页 | 激情综合五月 | 国产特级毛片aaaaaa | 国产一区二区在线不卡 | 啪网站| 中文字幕乱码中文字幕 | 邵氏电影《金莲外传2》免费观看 | 亚洲成人少妇 | 四虎免费久久 | 狼人精品一区二区三区在线 | 四虎网站 | 中文字幕免费看 | 影音先锋国产在线 | 日本japanese极品少妇 | 另类视频在线观看+1080p | 日本91在线| 欧美日韩一区在线播放 | 男人用嘴添女人下身免费视频 | 三上悠亚中文字幕在线播放 | 熟女肥臀白浆大屁股一区二区 | 特黄特色大片bbbb | 国产午夜精品久久久久久久久久 | 亚洲欧洲av| 97潮色| 神马午夜场 | av资源共享 | 一级黄av| 高潮毛片又色又爽免费 | av影视网| 超碰日韩在线 | 国产1区2区3区中文字幕 | 日本黄色片 | 国产亚洲成人精品 | 69堂免费视频 | 日本69少妇| 老司机深夜影院 | 午夜影院h| 欧美激情国产日韩精品一区18 | 日韩中文字幕免费在线观看 | 国产欧美精品久久久 | 欧美精品一区二区三区在线 | 国产妇女馒头高清泬20p多 | www.在线观看视频 | 欧美黄色免费观看 | 麻豆久久久久久久久久 | 欧美视频黄| av在线网址观看 | 国产精品16p | 亚洲最大福利网 | 99热热久久 | 99热99re6国产在线播放 | 日韩免费观看av | 欧美youjizz| 超碰69| 亚洲精品一区二区三区四区乱码 | 女人扒开双腿让男人捅 | 国产精品111 | 亚洲综合p | 人人九九精品 | 久精品免费视频 |