在本文中,我们将给您介绍关于在WEB中运行Flutter:错误:XMLHttpRequest错误的详细内容,并且为您解答flutterxml解析的相关问题,此外,我们还将为您提供关于DartXMLHt
在本文中,我们将给您介绍关于在 WEB 中运行 Flutter:错误:XMLHttpRequest 错误的详细内容,并且为您解答flutter xml解析的相关问题,此外,我们还将为您提供关于Dart XMLHttpRequest 错误故障排除 - 适用于 Flutter 移动设备,不适用于 Flutter Web、Flutter - XMLHttpRequest 已被 CORS 政策阻止、Flutter - 导致 XMLHttpRequest 错误的原因、Flutter 1.9 稳定版发布:Flutter for web 合并至 Flutter 主仓库、支持 macOS Catalina 和 iOS 13的知识。
本文目录一览:- 在 WEB 中运行 Flutter:错误:XMLHttpRequest 错误(flutter xml解析)
- Dart XMLHttpRequest 错误故障排除 - 适用于 Flutter 移动设备,不适用于 Flutter Web
- Flutter - XMLHttpRequest 已被 CORS 政策阻止
- Flutter - 导致 XMLHttpRequest 错误的原因
- Flutter 1.9 稳定版发布:Flutter for web 合并至 Flutter 主仓库、支持 macOS Catalina 和 iOS 13
在 WEB 中运行 Flutter:错误:XMLHttpRequest 错误(flutter xml解析)
如何解决在 WEB 中运行 Flutter:错误:XMLHttpRequest 错误
我在 Flutter 中构建了一个与 Android 应用程序完美运行的应用程序,但是当我尝试在 Chrome 中运行相同的应用程序时,我收到以下错误。正如你在错误中看到的,我没有任何对我的代码的引用,只是为了“dart-sdk/lib”。
我该如何解决这个问题?
**** 错误信息 ****
Launching lib\\main.dart on Chrome in debug mode...
Waiting for connection from debug service on Chrome...
Debug service listening on ws://127.0.0.1:52742/ewRwL069luw=/ws
Running with unsound null safety
For more information see https://dart.dev/null-safety/unsound-null-safety
Debug service listening on ws://127.0.0.1:52742/ewRwL069luw=/ws
Error: XMLHttpRequest error.
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/_internal/js_dev_runtime/patch/core_patch.dart 906:28 get current
packages/http/src/browser_client.dart 84:22 <fn>
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/zone.dart 1446:54 runUnary
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/future_impl.dart 150:18 handleValue
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/future_impl.dart 703:44 handleValueCallback
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/future_impl.dart 732:32 _propagatetoListeners
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/future_impl.dart 526:7 [_complete]
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/stream_pipe.dart 61:11 _cancelAndValue
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/async/stream.dart 1302:7 <fn>
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/_internal/js_dev_runtime/private/ddc_runtime/operations.dart 324:14 _checkAndCall
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/_internal/js_dev_runtime/private/ddc_runtime/operations.dart 329:39 dcall
C:/b/s/w/ir/cache/builder/src/out/host_debug/dart-sdk/lib/html/dart2js/html_dart2js.dart 37312:58 <fn>
at Object.createErrorWithStack (http://localhost:52678/dart_sdk.js:4368:12)
at Object._rethrow (http://localhost:52678/dart_sdk.js:38289:16)
at async._AsyncCallbackEntry.new.callback (http://localhost:52678/dart_sdk.js:38283:13)
at Object._microtaskLoop (http://localhost:52678/dart_sdk.js:38115:13)
at _startMicrotaskLoop (http://localhost:52678/dart_sdk.js:38121:13)
at http://localhost:52678/dart_sdk.js:33618:9
解决方法
您进行网络请求?
如果是这样,你需要改变你的后端的CORS政策允许的。
View here
Dart XMLHttpRequest 错误故障排除 - 适用于 Flutter 移动设备,不适用于 Flutter Web
如何解决Dart XMLHttpRequest 错误故障排除 - 适用于 Flutter 移动设备,不适用于 Flutter Web
我对 Dart 还很陌生,我很难解决这个出现在此处的大量问题中的错误:
Error: XMLHttpRequest error.
我的真实场景是一个 Flutter 网络应用程序,它应该会命中 Google Cloud Function,但本着 MWE 的精神,我用这个 Dart 复制了这个问题:
import ''dart:developer'';
import ''dart:convert'';
import ''package:http/http.dart'' as http;
Future<void> main() async {
final response = await http.post(
Uri.https(
//''jsonplaceholder.typicode.com'',''albums''),''my-region-my-project.cloudfunctions.net'',''/remainingTrigger''),headers: <String,String>{
//''Content-Type'': ''application/json; ''
// ''charset=UTF-8'',''Content-Type'': ''application/json''
},body: jsonEncode(<String,String>{
//''title'': ''test'',''ingredients'': ''test'',}),);
log(''response was ${response.body}'');
}
headers
注释似乎没有任何区别,但如果我翻转其他注释,它与 JSONPlaceholder 一起工作正常。如果我在终端中使用 curl
命中我的 Cloud Function
$ curl -X POST -H "Content-Type: application/json" -d ''{"ingredients": "test"}'' https://my-region-my-project.cloudfunctions.net/remainingTrigger
{"key":"value","otherKey":"otherValue"}
它工作正常。我最初确实遇到了 CORS 问题(我的 Cloud Function 日志显示为 417),但在我添加之后
from flask import abort
def entryPoint(request):
if request.method == ''OPTIONS'':
headers = {
''Access-Control-Allow-Origin'': ''*'',''Access-Control-Allow-Methods'': ''POST'',''Access-Control-Allow-Headers'': ''Content-Type'',''Access-Control-Max-Age'': ''3600''
}
return ('''',204,headers)
...
headers = {
''Access-Control-Allow-Origin'': ''*''
}
...
return (expectedOutput,200)
...
else:
return abort(417)
Cloud Function 日志开始显示正常行为(先是 204,然后是 200)。如果 Cloud Function 说一切正常,而 Dart 不同意,这是否排除了 CORS 作为罪魁祸首?我只处理过一次 CORS,但我非常相似地设置了 Cloud Function,Web 开发人员能够与它进行良好的交互。
回溯对我来说是希腊语;有人对辨别导致错误的 XMLHttpRequest
类型的问题有什么建议吗?
我主要在运行在 Windows 10 Home(http: ^0.13.1
、Dart SDK 2.12.2、Flutter 2.0.4、Android SDK 29.0.2)上的 Android Studio 4.1.3(Chrome 模拟器)中解决这个问题,但是还构建并部署了一次到我的网站,但遇到了同样的错误 (Safari)。我正在 Big Sur 11.0.1 上从 Docker 容器部署 Cloud Function(Python 3.8 运行时),但我认为这没有什么不同。
更新 1
令我惊讶的是,当我在 Android Studio 的 Android 模拟器(Pixel 3、API 30、Android 11.0)中尝试我的代码时,这运行良好。只是 Flutter web 尝试失败了(我现在已经通过 Android Studio 尝试了 Chrome 和 Edge,以及生产中的 Safari)。还有其他人看到这种行为吗?
更新 2
我也在供应商的 API 中看到了这种行为,因此它不是特定于我的 Google Cloud Function。 Flutter for web 和 JSONPlaceholder API 的结合是否有什么特别之处?
Flutter - XMLHttpRequest 已被 CORS 政策阻止
如何解决Flutter - XMLHttpRequest 已被 CORS 政策阻止
我正在处理 Flutter,在我的 PHP API 中,我放置了这些标头:
header(''Content-Type: application/json'');
header(''Access-Control-Allow-Origin: *'');
header(''Access-Control-Allow-Methods: GET'');
header("Access-Control-Allow-Headers: X-Requested-With");
但我仍然有答案:
“Access to XMLHttpRequest at ''http://localhost/spring_Box/api.PHP'' from origin ''http://localhost:52502'' has been blocked by CORS policy: The ''Access-Control-Allow-Origin''
”
你能帮我解决我的问题吗?
解决方法
按照以下步骤操作
1- 转到 flutter\\bin\\cache 并删除名为:flutter_tools.stamp 的文件
2- 转到 flutter\\packages\\flutter_tools\\lib\\src\\web 并在文本编辑器中打开文件 chrome.dart。
3- 搜索并找到“--disable-extensions”
4- 添加“--disable-web-security”
5- 保存。立即尝试
快乐编码。
Flutter - 导致 XMLHttpRequest 错误的原因
如何解决Flutter - 导致 XMLHttpRequest 错误的原因
我想知道 http 包抛出的 ''XMLHttpRequest Error'' 是否总是由于缺少 CORS 策略标头?
在此实例中抛出的期望类型为 ClientException - 我唯一能读取的内容是消息 (XMLHttpRequest Error) 和 uri。那么我怎么知道是因为上述原因。
我在日志中收到间歇性(且不常见)的错误,并且在服务器上正确设置了 CORS 策略标头。
我想排除 XMLHttpRequest 错误的任何其他原因。有什么想法吗?
Flutter 1.9 稳定版发布:Flutter for web 合并至 Flutter 主仓库、支持 macOS Catalina 和 iOS 13
昨日在上海举办的中国 Google 开发者大会(Google Developer Days China)上,Flutter 团队在主题演讲环节中发布了 Flutter 的最新稳定版本:Flutter 1.9。据称,此版本是 Flutter 迄今为止最大的一次版本更新,有 100 多名 contributor 在此次开发周期中提交了超过 1500 个 PR。新增的功能和其他更新涵盖了相当广泛的范围,从支持 macOS Catalina 和 iOS 13 到改进工具链,以及支持新的 Dart 语言特性和新的 Material 风格小部件。
在演讲环节,Flutter 团队还宣布了一则关于 Flutter 对 web 支持的重要里程碑消息:开发团队已成功将此前独立的 Flutter for web 集成到 Flutter 的主仓库中。
Flutter for web 是 Flutter 的代码兼容(code-compatible)实现版本,在 2019 年的谷歌 I/O 大会上,开发团队发布了 Flutter for web 的首个技术预览版,宣布 Flutter 正在为包括 Google Home Hub 在内的 Google 智能显示平台提供支持,并通过结合 Chrome OS 为桌面级应用程序提供支持迈出第一步。
Flutter for web 使用基于标准的 Web 技术(HTML, CSS 和 JavaScript)进行渲染。通过 Flutter for web,可以将 Dart 编写的 Flutter 代码编译成嵌入到浏览器并部署到任何 Web 服务器的客户端版本(client experience)。开发者可以使用 Flutter 的所有特性而无需浏览器插件。
现在 Flutter for web 集成至 Flutter 主仓库则意味着开发者可使用同一套代码库编写移动、桌面和 Web 应用。
下面简单介绍一下 Flutter 1.9 的新特性。
Flutter on the web
正如前面所提到的,flutter_web 的 GitHub 仓库现已被弃用,这个实现 Flutter 对 web 支持的仓库已合并至 Flutter 的主仓库中。亦即意味着,如果我们从 master 或 dev 分支获取到最新版本的 Flutter,只需运行 flutter run -d chrome 命令即可使用最新的 Flutter 试验版本来开发面向 Web 平台的应用。
当我们创建一个项目时,Flutter 现在会通过一个最小化的 web/index.html 文件来生成一个 web 运行引擎(web runner),其中 web/index.html 文件主要用于自举 (bootstrap) 基于 web 编译的 Flutter 代码,有了此文件后,我们可使用 Flutter CLI 工具或 IDE 中的 Flutter 插件来编辑或运行面向 Web 平台开发的 Flutter 应用。
上图是启用了 Flutter web 支持的 VS Code 界面截图。请注意 web/index.html 文件和顶部的下拉列表,可以看到这里允许开发者选择 Chrome 作为目标设备。尽管 Flutter 的 web 支持仍处于早期阶段,但 Flutter 1.9 代表了使用 Flutter 为 Web 开发提供生产支持走出了重要的一步。
下面是两个使用 Flutter 开发 Web 应用的案例:
Flutter Widget Livebook 使用 Flutter for web 构建,可展示在网页上实时运行的小部件。
Panache 则是一个用于为 Flutter 创建主题的工具,开发者可以下载已创建的主题,然后直接添加到代码中。
支持 macOS Catalina 和 iOS 13
苹果将在近期推出了新版本的 macOS 操作系统 Catalina。为此,团队付出了巨大努力,以确保 Flutter 做好升级准备,顺利适配新平台。比如说,新版本进一步优化了端到端的工具体验,保证 Flutter 工具能够与 Xcode 妥善协作,助力开发者面向 Catalina 开发出优质应用,具体优化项包括:
-
为新的 Xcode 构建系统提供支持
-
全工具链启用 64 位支持
-
简化平台依赖项
此外,随着 iOS 13 即将面世,团队也在积极推进相关的支持工作,以确保 Flutter 应用在新款 iPhone 设备上保持美观的界面。Flutter 1.9 实现了 iOS 13 的拖曳式工具栏功能,允许长按与从右往左拖动两项操作,并且为触感反馈提供了支持。不少开发者提交的希望 Flutter 支持 iOS 夜间模式的 pull request 已被合并,团队目前已开始着手解决这方面的需求,争取尽早推出解决方案。
最后,新版本的开发构建允许我们启用 Bitcode 实验性支持。Bitcode 是苹果新添加的一个编译特性,开启 Bitcode 功能后,开发者只需在编译环节上传与平台无关的 Intermediate Representation (中间文件) 即可。以 Bitcode 的形式上传应用后,苹果可以在后期直接对二进制文件进行优化,免除了开发者二次上传的麻烦。与此同时,这也为 Flutter 开启了更多的使用场景,比方说为 watchOS 和 tvOS 等要求上传 Bitcode 文件的平台提供支持。
引入全新的 Material 风格小部件
Flutter 1.9 也对 Material 组件和特性进行了升级。作为一款全球顶尖的开源设计系统,Material 提供了丰富多彩、灵活易操作的视觉元素,助力开发者在多个平台实现高交互性的用户体验。
在 Flutter 1.9 中,开发团队新添加了若干小部件,其中包括 ToggleButtons 和 ColorFiltered。
▲ ToggleButtons
▲ ColorFiltered
ToggleButtons widget 可将同一行的多个 ToggleButton widget 组合到一起,其中每个 widget 各自又由一组图标和文本 widget 构成。通过这种组合,开发者将得到一组外观与行为完全可自定义的按钮。它能为您的应用按钮实现更加多元化的设计 —— 不论是单选还是多选,选择至少一个或是零个、尖角还是圆角、粗边或细边,图标或文本 ——ToggleButtons widget 全都可以满足。请查看 ToggleButtons 示例,了解以上需求的具体实现。
ColorFiltered widget 允许我们更改子 widget 树的颜色,这与利用算法 (部分算法见上图样例) 给图片重新上色差不多。该 widget 能够帮助我们处理许多用例,例如: 向用户提供更好的色彩无障碍服务等等。请查看 ColorFiltered 示例,了解该 widget 的工作细节。
国际化支持
新增了对南非语 (Afrikaans)、祖鲁语 (Zulu) 等 24 种多国语言的支持。
Dart 2.5
在 Flutter 1.9 发布之际,Google 也推出了最新版本的 Dart 语言 —— Dart 2.5,内含预发布版本的 Dart: FFI (外部函数接口),它可用于实现 Dart 语言与 C 语言之间的互操作 (interop),以及由机器学习驱动的 IDE/编辑器代码补全功能。更多技术细节,请阅读后续发布的《Dart 2.5 发布说明》。
优化工具链
从 Flutter 1.9 开始,iOS 新项目默认使用 Swift 语言,而非 Objective-C;Android 新项目则默认使用 Kotlin,而非 Java。由于许多 Flutter package 使用 Swift 编写,因此,一旦将 Swift 设置为默认语言后,开发者便无需再为启用默认设置的应用手动添加包。Swift 5 实现了 ABI 稳定,而且苹果在近期几个系统版本中也为应用瘦身做了许多工作,因此 12.2 或更高版本的 iOS 系统将不再包含用于 Swift 的动态链接库,从而大幅缩小了 Swift 应用的体积。
考虑到 Android Studio 新项目现在已经默认采用 Kotlin 作为开发语言了,因此,很自然地,Flutter 开发团队把所有 Android 项目的默认语言统一为 Kotlin。flutter CLI 工具、IntelliJ/Android Studio 和 VS Code 插件均默认启用这些选项,不过,如有需要,我们可随时切换回之前的 Objective-C 或 Java 语言。
此外,开发团队也在一直改善 Flutter 应用中的错误信息质量。优化之后,信息的可读性、简洁性和可操作性均有明显提升。
参考:谷歌开发者 《Flutter 1.9 正式发布!| 全平台创新开发体验》
今天关于在 WEB 中运行 Flutter:错误:XMLHttpRequest 错误和flutter xml解析的讲解已经结束,谢谢您的阅读,如果想了解更多关于Dart XMLHttpRequest 错误故障排除 - 适用于 Flutter 移动设备,不适用于 Flutter Web、Flutter - XMLHttpRequest 已被 CORS 政策阻止、Flutter - 导致 XMLHttpRequest 错误的原因、Flutter 1.9 稳定版发布:Flutter for web 合并至 Flutter 主仓库、支持 macOS Catalina 和 iOS 13的相关知识,请在本站搜索。
本文标签: