带有烧瓶 API 的 CORs 请求 - Jquery POST 请求在 OPTION 中产生



我有一个烧瓶API来控制浸入式加热器设备。

https://github.com/timcknowles/anovapi_backend/blob/master/anova.py

这是在我的本地主机服务器上,它可以正确响应同一域上的 JQuery POST 请求,例如

$(document).ready(function() {
            $("#start").click(function() {
                    $.ajax({
                      type: 'post',
                      url: 'http://192.168.0.13:5000/start',
                      dataType: 'jsonp',
                      success: function(data) {
                         $("#message").html(data);
                      }

$("#settemp").click(function() {
                    $.ajax({
                      type: 'post',
                      contentType: 'application/json',
                      url: ' http://192.168.0.13:5000/temp',
                      data: JSON. stringify ({"temp":"50"}),
                      dataType: 'json',
                      success: function(data) {
                         $("#message").html(data);
                      }
            });

但是我想在不同的服务器上构建一个 sinatra 客户端应用程序

https://github.com/timcknowles/anovapi_frontend/blob/master/main.rb

与同一 API 交互。jquery是相同的,对于START调用工作正常,但是对于TEMP调用,它不起作用

在Firefox的开发人员控制台中,我可以看到它具有OPTIONS而不是POST请求(响应200)。

最初,我的所有 api jQuery 请求都遇到了跨域问题,我认为我已经通过将烧瓶 cors 扩展添加到我的 api 来解决这些问题。

https://pypi.python.org/pypi/Flask-Cors

我不明白为什么临时呼叫不起作用,但其他呼叫不起作用。我怀疑这是因为我以温度值的形式发送数据。

任何建议非常感谢。

我认为您需要初始化CORS()才能使Flask工作。

尝试将其放在 python 服务器的第 12 行:

cors = CORS(app, resources={r"/*": {"origins": "*"}})
你也可以只用

CORS(app)(我从来没有使用过Flask,所以我不确定)。

有关详细信息,请参阅简单用法下的 Flask 文档。

最新更新