Flask正确的方法来处理来自前端的AJAX调用错误

时间:2017-02-17 08:54:07

标签: javascript python ajax reactjs flask

我有一个与Python Flask服务器通信的React应用程序。

我正在实施一项允许用户更改密码的功能。从React到Flask的AJAX请求。这将发送旧密码和新密码。

我在前端进行所有检查,以确保密码符合要求。

从前端Flask发送数据后,检查旧密码是否正确,然后更新新密码。这会将200响应发送回客户端。当一切都成功时,我没有任何问题。

但是,我不确定在用户发送200状态的情况下该怎么做,但返回的json消息不同。

我的问题是,是否应该在此阶段发送错误回复。

这是我的代码看起来像

@customer.route('/update-password', methods=['POST'])
def update():
    current_password=request.json['currentPassword']
    password=request.json['newPassword']

    login_response = engine.login('testUser', current_password)
    if login_response.get('success'):
        password_response = engine.update_user_password(password=password)
        if password_response.get('success'):
            return jsonify(message='password_updated_success')
        else:
            return jsonify(message='password_update_error')
    else:
        return jsonify(message='incorrect_password_provided')

这是我的前端代码

axios.post('update-password', {
    currentPassword: oldPassword,
    newPassword: newPassword
}).then(response => {
    dispatch(updatePasswordSuccess());
    resolve(response);
}).catch(err => {
   dispatch(updatePasswordError());
   reject(err);
});

1 个答案:

答案 0 :(得分:2)

更改您的响应结构,以便将一个相关的HTTP错误代码(如500)显式发送到您的前端代码,以便AJAX识别出发生了错误。

基本上是这样的:

return jsonify(message='password_update_error'),500

有关此

的详细信息,请参阅Flask文档here