Flutter - 平台不允许不安全的套接字连接:10.0.2.2
Flutter - Insecure socket connections are disallowed by platform: 10.0.2.2
从今天开始,每当我尝试登录我的应用程序时,我都会收到 Dio 包抛出的以下错误:SocketException:平台不允许不安全的套接字连接:10.0.2.2
我使用以下设置进行连接:
static BaseOptions options = new BaseOptions(
baseUrl: "http://10.0.2.2:3000", // on android emulator
connectTimeout: 5000,
receiveTimeout: 3000)
因此,类似的东西(我在 /user/login 进行了身份验证设置并正常运行):
var apiLogin = api.dio;
try {
Response response = await apiLogin.post("/user/login",
options: Options(contentType: "application/json"),
data: {"email": email, "password": password});
} on DioError catch (e) {
throw Exception([e]);
}
我在连接到(容器化)mongodb 的端口 3000 上有一个节点服务器 运行。尝试身份验证时,它立即出现 DioError,我无法在线找到任何地方的原因。
有人知道这个错误与什么有关吗?
编辑[答案]
感谢 @lyrics 为我指明了正确的方向:
从 API 级别 27 及更高级别开始,usesCleartextTraffic 默认为 false,因此会阻止传出的 http 请求,需要 HTTPS。
解决方案是将以下内容添加到 AndroidManifest.xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest ...>
<uses-permission android:name="android.permission.INTERNET" />
<application
...
android:usesCleartextTraffic="true"
...>
...
</application>
</manifest>
如
所述
来源:https://developer.android.com/guide/topics/manifest/application-element#usesCleartextTraffic
你好像刚升级到Android10,你可能不知道HTTPS是默认的以Android9开头的连接协议,所有不使用Https的连接都会失败。
阅读更多 https://developer.android.com/training/articles/security-config.html
在此处查看此答案
第一个 add-in AndroidManifest 文件
在结束标记之前添加这一行
<uses-permission android:name="android.permission.INTERNET" />
在开头添加这一行
找到这个标签,先把它加进去
<application
android:usesCleartextTraffic="true"
我在 ios 模拟器和 Android 模拟器上对 Flutter 运行 也有类似的问题:
SocketException: Insecure socket connections are disallowed by platform:
在 Flutter 项目中转到:
要在 Ios 中启用:
ios 文件夹 -> runner 文件夹 -> info.plist
然后添加以下行以启用 HTTP 请求:
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
要在 Android 中启用:
Android 文件夹 -> app -> src -> main -> AndroidManifest.xml
添加此权限:
<uses-permission android:name="android.permission.INTERNET"/>
然后在应用程序标签中添加以下行:
android:usesCleartextTraffic="true"
我打电话给-
响应 response = await get('http://worldtimeapi.org/api/timezone/Asia/Kolkata');
我只是将 http 替换为 https 并且它已修复。
新请求是-
响应 response = await get('https://worldtimeapi.org/api/timezone/Asia/Kolkata');
这解决了我的问题。
从今天开始,每当我尝试登录我的应用程序时,我都会收到 Dio 包抛出的以下错误:SocketException:平台不允许不安全的套接字连接:10.0.2.2
我使用以下设置进行连接:
static BaseOptions options = new BaseOptions(
baseUrl: "http://10.0.2.2:3000", // on android emulator
connectTimeout: 5000,
receiveTimeout: 3000)
因此,类似的东西(我在 /user/login 进行了身份验证设置并正常运行):
var apiLogin = api.dio;
try {
Response response = await apiLogin.post("/user/login",
options: Options(contentType: "application/json"),
data: {"email": email, "password": password});
} on DioError catch (e) {
throw Exception([e]);
}
我在连接到(容器化)mongodb 的端口 3000 上有一个节点服务器 运行。尝试身份验证时,它立即出现 DioError,我无法在线找到任何地方的原因。
有人知道这个错误与什么有关吗?
编辑[答案]
感谢 @lyrics 为我指明了正确的方向: 从 API 级别 27 及更高级别开始,usesCleartextTraffic 默认为 false,因此会阻止传出的 http 请求,需要 HTTPS。
解决方案是将以下内容添加到 AndroidManifest.xml:
<?xml version="1.0" encoding="utf-8"?>
<manifest ...>
<uses-permission android:name="android.permission.INTERNET" />
<application
...
android:usesCleartextTraffic="true"
...>
...
</application>
</manifest>
如
来源:https://developer.android.com/guide/topics/manifest/application-element#usesCleartextTraffic
你好像刚升级到Android10,你可能不知道HTTPS是默认的以Android9开头的连接协议,所有不使用Https的连接都会失败。 阅读更多 https://developer.android.com/training/articles/security-config.html
在此处查看此答案
第一个 add-in AndroidManifest 文件
在结束标记之前添加这一行
<uses-permission android:name="android.permission.INTERNET" />
在开头添加这一行 找到这个标签,先把它加进去
<application
android:usesCleartextTraffic="true"
我在 ios 模拟器和 Android 模拟器上对 Flutter 运行 也有类似的问题:
SocketException: Insecure socket connections are disallowed by platform:
在 Flutter 项目中转到:
要在 Ios 中启用:
ios 文件夹 -> runner 文件夹 -> info.plist
然后添加以下行以启用 HTTP 请求:
<key>NSAppTransportSecurity</key>
<dict>
<key>NSAllowsArbitraryLoads</key>
<true/>
</dict>
要在 Android 中启用:
Android 文件夹 -> app -> src -> main -> AndroidManifest.xml
添加此权限:
<uses-permission android:name="android.permission.INTERNET"/>
然后在应用程序标签中添加以下行:
android:usesCleartextTraffic="true"
我打电话给- 响应 response = await get('http://worldtimeapi.org/api/timezone/Asia/Kolkata');
我只是将 http 替换为 https 并且它已修复。
新请求是- 响应 response = await get('https://worldtimeapi.org/api/timezone/Asia/Kolkata');
这解决了我的问题。