0

我有一个烧瓶 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 请求都存在跨域问题,我认为我已经通过将 flask cors 扩展添加到我的 api 来解决这些问题。

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

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

任何建议都非常感谢。

4

1 回答 1

1

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

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

cors = CORS(app, resources={r"/*": {"origins": "*"}})

你也可以侥幸逃脱CORS(app)(我从来没有使用过 Flask,所以我不确定)。

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

于 2016-04-23T15:51:58.110 回答