Extraño error "is_xhr" al implementar la aplicación Flask en Heroku

29

Tengo una aplicación de matraz que he implementado en Heroku, una de las rutas es la siguiente

def get_kws():
    seed_kw = request.json['firstParam']
    audience_max = request.json['secondParam']
    interest_mining_service = InterestMiningService(seed_kw, audience_max)
    query_result = interest_mining_service.query_keyword().tolist()
    if seed_kw in query_result:
        print ("yes")
        return jsonify(
            {
             'keyword_data' : interest_mining_service.find_kws().to_json(orient='records'),
             'query_results': query_result
            }
        )

Cuando pruebo este punto final localmente, no tengo problemas al enviar solicitudes POST y GET a ese punto final. Sin embargo, cuando lo implemento en Heroku, aparece el siguiente error:

File "/app/server/controller.py", line 24, in get_kws
2020-02-08T22:31:05.893850+00:00 app[web.1]: 'query_results': query_result
2020-02-08T22:31:05.893850+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/flask/json.py", line 298, in jsonify
2020-02-08T22:31:05.893851+00:00 app[web.1]: if current_app.config['JSONIFY_PRETTYPRINT_REGULAR'] and not request.is_xhr:
2020-02-08T22:31:05.893851+00:00 app[web.1]: File "/app/.heroku/python/lib/python3.6/site-packages/werkzeug/local.py", line 347, in __getattr__
2020-02-08T22:31:05.893852+00:00 app[web.1]: return getattr(self._get_current_object(), name)
2020-02-08T22:31:05.893858+00:00 app[web.1]: AttributeError: 'Request' object has no attribute 'is_xhr'

Nunca he visto este error Request object has no attribute 'is_xhr'antes y solo parece estar sucediendo cuando lo implemento en Heroku. ¿Alguna orientación sobre lo que debería analizar?

Tampoco parece haber un problema con la clave json keyword_data: el problema parece limitado a query_resultscuál es una lista.

Tom Jackson
fuente

Respuestas:

39

La Werkzeugbiblioteca (dependencia de Flask) recibió recientemente una actualización importante (0.16.1 -> 1.0.0) y parece que Flask(<= 0.12.4) no la restringe.

Tienes 2 opciones:

  • Quédese con su versión actual de Flask y restrinja la versión de Werkzeug que se obtiene explícitamente en setup.py o require.txt ( werkzeug<1.0) de su aplicación

  • Actualice a una versión reciente de Flask (> = 1.0.0), que funciona bien con el último Werkzeug

bagerard
fuente
0

También me he enfrentado a este problema.

Solo arreglado temporalmente al registrar directamente el encabezado de la solicitud

request.headers.get("X-Requested-With") == "XMLHttpRequest"

No estoy seguro de esta ayuda ...

Jing
fuente