2

我有一个 Flask 应用程序,其路线如下所示:

from _mysql_exceptions import OperationalError

@mod.route('/', methods=['POST'])
def do_something_route():
    try:
        do_something(request.form)
    except OperationalError:
        message = {"error": "something went wrong"}
        return jsonify(message, mimetype='application/json'), 400

do_something()功能:

def do_something(self, form_data):
    model = MyModel()
    for key in form_data:
        if hasattr(model, key):
            setattr(model, key, form_data.get(key))
    db.session.add(model)
    db.session.commit()
    return model

当我将垃圾数据发送到do_something_route违反我的数据库约束的地方时,OperationalError会引发异常并返回状态代码为 500 的响应并返回堆栈跟踪,而不是状态为 400 的我的 jsonified 消息。

当我尝试这是一个普通的旧 python shell 时,它似乎按预期工作:

>>> from _mysql_exceptions import OperationalError
>>> raise OperationalError
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
_mysql_exceptions.OperationalError

>>> try:
...     raise OperationalError
... except OperationalError:
...     print 'test'
...
test

为什么except OperationalError:不捕获OperationalError异常?Flask 是否在做一些能提前返回响应的黑魔法?

4

1 回答 1

1
from  sqlalchemy.exc import OperationalError
try:
     # do something
except OperationalError:
     # do something
于 2020-07-07T11:45:58.797 回答