dart-server/angulardart 和 CORS 的问题

2023-12-14

我在我的服务器上使用 dart,并使用 angulardart 作为我的客户端。我可以通过我的服务器上的 http.get 请求数据,工作正常 - 但我无法让 POST 工作。

服务器:(服务器使用“开始”https://github.com/lvivski/start)

//runs at 127.0.0.1:4040:
server.post("/rest/qr").listen((request) {
  addCorsHeaders(request.response);
  request.payload().then((map) {
    print(map);
  }).then((_) {
    request.response.send("ok");
  });
});

客户端(角度):

// runs at http://127.0.0.1:3030
final String _codesUrl = "http://127.0.0.1:4040/rest/qr";
_http.post(_codesUrl, JSON.encode(temp.toMap())).then((HttpResponse response) {
  print(response.status);
});

添加CorsHeaders:

void addCorsHeaders(Response res) {
    res.header("Access-Control-Allow-Origin", "*, ");
    res.header("Access-Control-Allow-Methods", "POST, GET, OPTIONS");
    res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept");}

这是我的代码。正如我已经说过的,从 Angular 到我的服务器的 http.get 确实有效。通过 Angular http-service 发布到我的服务器失败:“请求的资源上不存在“Access-Control-Allow-Origin”标头。因此不允许访问 Origin“127.0.0.1:3030”。”

我还尝试了 Google Chrome 中的高级休息插件来向该 URL 发出 POST 请求。这些请求确实有效。我是否错过了 angulardart POST 请求中的某些内容?服务器和客户端运行在不同的端口上。


我自己也遇到过这个问题。事实证明,某些 CORS 请求需要“预检请求”。 GET 不会,但 POST 会。以下文章详细解释了这一切:

http://www.html5rocks.com/en/tutorials/cors/#toc-adding-cors-support-to-the-server

要点是,对于 POST CORS 请求,客户端将首先向服务器发送“OPTIONS”请求,询问 CORS POST 是否正常。这就是我之前提到的“飞行前请求”。您需要捕获它并回复它,然后才能收到 POST。

我不确定如何使用 Start 框架回答 OPTIONS 请求,但 dartlang 网站有一个关于如何使用 vanilla dart 解决确切问题的教程:

https://www.dartlang.org/docs/tutorials/forms/#handling-options-requests

处理 OPTION 请求的代码(摘自上面的文章):

void handleOptions(HttpRequest req) {
  HttpResponse res = req.response;
  addCorsHeaders(res);
  print('${req.method}: ${req.uri.path}');
  res.statusCode = HttpStatus.NO_CONTENT;
  res.close();
 }
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

dart-server/angulardart 和 CORS 的问题 的相关文章

随机推荐