c ++ отправить json в python flask [duplicate]

Js - однопоточная.

blockquote>

Браузер можно разделить на три части:

1) Event Loop

2 ) Web API

3) Очередь событий

Событие Loop запускается вечно, т. Е. Тип бесконечного цикла. Очередь ожидания - это то, где вся ваша функция нажимается на какое-либо событие (пример: нажмите) this один за другим выполняется в очереди и помещается в цикл «Событие», который выполняет эту функцию и подготавливает ее для следующего после первого запуска. Это означает, что выполнение одной функции не начинается до тех пор, пока функция, перед которой она в очереди не будет выполнена цикл событий.

Теперь давайте подумаем, что мы поставили две функции в очереди, чтобы получить данные с сервера, а другой использует эти данные. Мы сначала нажали функцию serverRequest () в очереди, а затем применили функцию Data () , Функция serverRequest переходит в цикл событий и делает вызов на сервер, так как мы никогда не знаем, сколько времени потребуется для получения данных с сервера, поэтому ожидается, что этот процесс займет много времени, и поэтому мы заняли наш цикл событий, тем самым повесив нашу страницу, вот где Web API входит в эту роль, он принимает эту функцию из цикла событий и обращается к серверу, создающему цикл событий, так что мы можем выполнить следующую функцию из очереди. Следующая функция в очереди - useData (), которая идет в цикле, но из-за отсутствия данных отходы и выполнение следующей функции продолжаются до конца очереди (это называется Async-вызовом, то есть мы можем сделать что-то еще, пока не получим данные)

Предположим, что наша функция serverRequest () имела оператор возврата в код, когда мы возвращаем данные с сервера Web API, будет выталкивать его в очередь в конце очереди. По мере того, как он заканчивается в очереди, мы не можем использовать его данные, поскольку в нашей очереди нет функции, чтобы использовать эти данные. Таким образом, невозможно вернуть что-то из Async Call.

Таким образом, решение этой проблемы callback или обещают .

A Изображение из одного из ответов здесь, правильно объясняет использование обратного вызова ... Мы (функция, использующая данные, возвращаемые с сервера), чтобы вызвать вызывающий сервер.

 function doAjax(callbackFunc, method, url) {
  var xmlHttpReq = new XMLHttpRequest();
  xmlHttpReq.open(method, url);
  xmlHttpReq.onreadystatechange = function() {

      if (xmlHttpReq.readyState == 4 && xmlHttpReq.status == 200) {
        callbackFunc(xmlHttpReq.responseText);
      }


  }
  xmlHttpReq.send(null);

}

В моем коде он называется

function loadMyJson(categoryValue){
  if(categoryValue==="veg")
  doAjax(print,"GET","http://localhost:3004/vegetables");
  else if(categoryValue==="fruits")
  doAjax(print,"GET","http://localhost:3004/fruits");
  else 
  console.log("Data not found");
}

Прочитайте здесь новые методы в ECMA (2016/17) для создания асинхронного вызова (@Felix Kling Answer сверху) https://stackoverflow.com/a/14220323/7579856

170
задан Martijn Pieters 3 March 2015 в 15:26
поделиться

4 ответа

Вам нужно установить тип содержимого запроса application/json для свойства .json; это будет None в противном случае. См. Документацию Flask Request :

Если тип mimetype application/json, это будет содержать проанализированные данные JSON. В противном случае это будет None.

Flask 0.10 добавил метод request.get_json() , и вы должны использовать этот метод вместо свойства .json. Вы можете сообщить методу пропустить требование типа содержимого, установив force=True.

Обратите внимание, что если в этот момент возникает исключение (возможно, это приводит к ответу 400 Bad Request ), данные JSON недействительны. Он каким-то образом искажен; вы можете проверить его с помощью валидатора JSON.

254
ответ дан Martijn Pieters 26 August 2018 в 08:21
поделиться

Для справки, вот полный код для отправки json из клиента Python:

import requests
res = requests.post('http://localhost:5000/api/add_message/1234', json={"mytext":"lalala"})
if res.ok:
    print res.json()

Вход «json =» автоматически установит тип содержимого, как описано здесь: Сообщение JSON с использованием запросов Python

И вышеупомянутый клиент будет работать с этим кодом на стороне сервера:

from flask import Flask, request, jsonify
app = Flask(__name__)

@app.route('/api/add_message/<uuid>', methods=['GET', 'POST'])
def add_message(uuid):
    content = request.json
    print content['mytext']
    return jsonify({"uuid":uuid})

if __name__ == '__main__':
    app.run(host= '0.0.0.0',debug=True)
40
ответ дан Community 26 August 2018 в 08:21
поделиться

Так я бы это сделал, и это должно быть

@app.route('/api/add_message/<uuid>', methods=['GET', 'POST'])
def add_message(uuid):
    content = request.get_json(silent=True)
    print content
    return uuid

С установкой silent=True функция get_json не работает при попытке получить тело json. По умолчанию установлено значение False. Параметр force=True будет игнорировать request.headers.get('Content-Type') == 'application/json', чтобы флакон делался для вас. По умолчанию также установлено значение False. См. документацию флагов .

Я настоятельно рекомендую оставить force=False и заставить клиента отправить заголовок Content-Type, чтобы сделать его более явным.

Надежда это помогает!

41
ответ дан radtek 26 August 2018 в 08:21
поделиться

Это решение работает:

from flask import Flask, request, jsonify

app = Flask(__name__)


@app.route('/hello', methods=['POST'])
def hello():
   return jsonify(request.json)
3
ответ дан trojek 26 August 2018 в 08:21
поделиться
Другие вопросы по тегам:

Похожие вопросы: