我正在开发我的第一个Flask应用程序(版本0.10.1),以及我的第一个Python(版本3.5)应用程序.其中一件需要像这样工作:
>提交表格
>运行Celery任务(进行一些第三方API调用)
>当Celery任务的API调用完成后,将JSON帖子发送到应用程序中的另一个URL
>获取该JSON数据并使用它更新数据库记录
这是Celery任务的相关部分:
if not response['errors']: # response comes from the Salesforce API call
# do something to notify that the task was finished successfully
message = {'flask_id' : flask_id,'sf_id' : response['id']}
message = json.dumps(message)
print('call endpoint now and update it')
res = requests.post('http://0.0.0.0:5000/transaction_result/',json=message)
这是它调用的端点:
@app.route('/transaction_result/',methods=['POST'])
def transaction_result():
result = jsonify(request.get_json(force=True))
print(result.flask_id)
return result.flask_id
到目前为止,我只是想获取数据并打印ID,之后我会担心数据库.
我得到的错误是:requests.exceptions.ConnectionError:无:使用url超出最大重试次数:/ transaction_result /(由None引起)
我的阅读表明我的数据可能不会以JSON的形式出现,因此结果上的Force = True,但即使这样也似乎不起作用.我也尝试在CocoaRestClient中使用application-json的Content-Type标头执行相同的请求,并得到相同的结果.
因为这两个尝试都破坏了,我无法判断我的问题是在请求中还是在尝试解析响应时.
最佳答案
首先,request.get_json(force = True)返回一个对象(如果silent = True,则返回None). jsonify将对象转换为JSON字符串.您正在尝试访问str_val.flask_id.不可能.但是,即使在删除多余的jsonify调用之后,您也必须将result.flask_id更改为result [‘flask_id’].
所以,最终代码应如下所示:
@app.route('/transaction_result/',methods=['POST'])
def transaction_result():
result = request.get_json()
return result['flask_id']
当您使用REST客户端测试路由时,您绝对正确.它通过减少相关部件来简化测试过程.从烧瓶应用程序向同一个应用程序发送请求期间的一个众所周知的问题是在开发服务器下运行此应用程序只有一个线程.在这种情况下,请求将始终被内部请求阻止,因为当前线程正在为最外层请求提供服务而无法处理内部请求.但是,由于您是从Celery任务发送请求,因此不太可能是您的方案.
UPD:最后,最后一个原因是IP地址0.0.0.0.将其更改为真实解决了问题.