欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

Flutter - 接入踩坑

程序员文章站 2022-06-11 19:19:06
...

Flutter - 接入踩坑

最近在研究 Flutter ,根据官网的教程,创建了项目后,打开了 Android 模拟器,启动项目。App 安装成功后,报错如下:

E/DartVM  (20928): vm-service: Error: Unhandled exception:
E/DartVM  (20928): WebSocketException: Invalid WebSocket upgrade request
E/DartVM  (20928): 
E/flutter (20928): [ERROR:flutter/runtime/dart_isolate.cc(865)] Unhandled exception:
E/flutter (20928): WebSocketException: Invalid WebSocket upgrade request
Error connecting to the service protocol: failed to connect to http://127.0.0.1:49855/tUl8jpG1mhw=/

根据报错的上下文提示,我猜 Flutter 可能使用 WebSocket 协议来双向传输数据,之前在做 Java Web 的时候,学习过一点 WebSocket 协议, WebSocket 协议和 HTTP 协议一样,同属于应用层协议,它的 Scheme 是 ws 或者 wss ,而不应该是 http,更确切的说法是建立连接的时候使用 http 协议,之后服务器返回了 101 ,表示对协议升级,表示接下来的通信要使用 WebSocket 协议。这里出现了 http ,很明显建立连接阶段网络出问题了:

Error connecting to the service protocol: failed to connect to http://127.0.0.1:49855/tUl8jpG1mhw=/

因此猜测可能是 Mac 电脑代理问题,为了开发方便,我的电脑时刻开着代理,在 .bash_profile 中也配置了代理。

于是我关闭了代理,发现还是不行。网上搜索了一圈,原来只需要在 .bash_profile 中添加:

export NO_PROXY=localhost,127.0.0.1

修改之后,又使用了:

source ~/.bash_profile

重启了 IDE ,发现还是同样报错,前前后后折腾了快一个小时, Google 、StackOverflw、Github 找了一圈没找到答案。

于是重启了 Mac 电脑,问题解决…


延伸

周末,使用另外一台 Mac 电脑进行验证,发现在 .bash_profile 中添加了 NO_PROXY 之后,调用了 source ~/.bash_profile,确实没有效果,添加之后重启 Mac 电脑即可。

相关标签: Flutter flutter