Ask*_*ken 10 python error-handling flask
我正在为我正在开发的应用编写REST API.该应用程序是用python写的.我有以下内容:
try:
_profile = profile(
name=request.json['name'],
password=profile.get_salted_password('blablabla'),
email=request.json['email'],
created_by=1,
last_updated_by=1
)
except AssertionError:
abort(400)
session = DatabaseEngine.getSession()
session.add(_profile)
try:
session.commit()
except IntegrityError:
abort(400)
Run Code Online (Sandbox Code Playgroud)
错误处理程序如下所示:
@app.errorhandler(400)
def not_found(error):
return make_response(standard_response(None, 400, 'Bad request'), 400)
Run Code Online (Sandbox Code Playgroud)
我正在使用错误400来表示sqlalchemy模型验证器的问题和写入数据库时的唯一约束,并且在这两种情况下都会向客户端发送以下错误:
{
"data": null,
"error": {
"msg": "Bad request",
"no": 400
},
"success": false
}
Run Code Online (Sandbox Code Playgroud)
有没有办法仍然使用abort(400),但也以某种方式设置错误,以便错误处理程序可以负责在结果中添加错误对象的附加信息?
我希望它更符合:
{
"data": null,
"error": {
"msg": "(IntegrityError) duplicate key value violates unique constraint profile_email_key",
"no": 400
},
"success": false
}
Run Code Online (Sandbox Code Playgroud)
你可以直接在abort()函数中放一个自定义响应:
abort(make_response("Integrity Error", 400))
Run Code Online (Sandbox Code Playgroud)
或者,您可以将其放在错误处理函数中
@app.errorhandler(400)
def not_found(error):
resp = make_response("Integrity Error", 400)
return resp
Run Code Online (Sandbox Code Playgroud)
errorhandler 也可以采用异常类型:
@app.errorhandler(AssertionError)
def handle_sqlalchemy_assertion_error(err):
return make_response(standard_response(None, 400, err.message), 400)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
10134 次 |
| 最近记录: |