raise error_codes.UNABLE_TO_UPVOTE
raise error_codes.USER_HAS_BEEN_BANNED
... ...
毫无意外,所有人都很喜欢用这种方式来返回错误码。因为它用起来非常方便辅助论坛,无论调用栈多深,只要你想给用户返回错误码,调用 raiseerror_codes.ANY_THING 就好。
随着时间推移,项目也变得越来越庞大,抛出 APIErrorCode 的地方也越来越多。有一天,我正准备复用一个底层图片处理函数时,突然碰到了一个问题。
我看到了一段让我非常纠结的代码:
# 在某个处理图像的模块内部
#
/util/image/processor.py
def process_image(...):
try:
image = Image.open(fp)
except Exception:
# 说明(非项目原注释):该异常将会被 Django 的中间件捕获,往前端返回
# "上传的图片格式有误" 信息
raise error_codes.INVALID_IMAGE_UPLOADED
... ...
process_image 函数会尝试解析一个文件对象,如果该对象不能被作为图片正常打开,就抛出 error_codes.INVALID_IMAGE_UPLOADED(APIErrorCode子类) 异常,从而给调用方返回错误代码 JSON。
让我给你从头理理这段代码。最初编写 process_image 时,我虽然把它放在了 util.image 模块里,但当时调这个函数的地方就只有 “处理用户上传图片的 POST 请求” 而已。为了偷懒,我让函数直接抛出 APIErrorCode 异常来完成了错误处理工作。
再来说当时的问题。那时我需要写一个在后台运行的批处理图片脚本,而它刚好可以复用 process_image 函数所实现的功能。但这时不对劲的事情出现了,如果我想复用该函数,那么:
我必须引入APIErrorCode异常类作为依赖来捕获异常
这就是异常类抽象层级不一致导致的结果。APIErrorCode 异常类的意义,在于表达一种能够直接被终端用户(人)识别并消费的“错误代码”。它在整个项目里,属于最高层的抽象之一。但是出于方便,我们却在底层模块里引入并抛出了它。这打破了 image.processor 模块的抽象一致性,影响了它的可复用性和可维护性。
这类情况属于“模块抛出了高于所属抽象层级的异常”。避免这类错误需要注意以下几点:
在必要的地方进行异常包装与转换
修改后的代码:
#
/util/image/processor.py
class ImageOpenError(Exception):
pass
def process_image(...):
try:
image = Image.open(fp)
except Exception as e:
raise ImageOpenError(exc=e)
... ...
#
/app/views.py
def foo_view_function(request):
try:
process_image(fp)
except ImageOpenError:
raise error_codes.INVALID_IMAGE_UPLOADED
除了应该避免抛出高于当前抽象级别的异常外,我们同样应该避免泄露低于当前抽象级别的异常。
电子书 当前页面的脚本发生错误 异常处理的三个好习惯 | Python 工匠
11/28 05:09:02 来源网站:seo优化-辅助卡盟平台卡盟推荐
更多>相关资讯
更多>-
【手游资讯】2016年10月21日最强数据分析
2022/08/24 -
四周年新服被挤爆《逆水寒》4年前开服造就万人排队盛况
2022/08/24 -
网站优化选择关键词是优化的第一步吗?你的困惑?
2022/08/24 -
世界顶级DJ艾维奇(Avicii)CrossfadeWireless蓝牙耳机评测
2022/09/15 -
北京医保局公布辅助生殖行业活报告就是“试管婴儿”
2022/09/15 -
网页游戏 第一的回答太个人化了,至少和我的个人化有偏差
2022/08/06 -
《守望先锋卡盟归来》“归来”开测在即,还没有账号
2022/09/15 -
1.暗黑元首辛德拉的皮肤特效重点在于球的模型变化和落地
2022/08/06 -
2017年《街头篮球卡盟》全国超级联赛地区赛结束后设立俱乐部荣誉殿堂
2022/09/15 -
网站地图与死链接检查制作工具网站优化跟网站维护的不同
2022/08/06 -
事实:电脑重装后没声音怎么办
2022/01/18 -
横空出世:五局拉满 Liquid击败VP获DOTA2 Supermajor冠军
2022/01/18 -
新科动漫论坛最核心的部分是什么?(图)
2022/09/15 -
财税实操内容--初始化平衡,需要注意如果账套启用时间
2022/09/15 -
,小霞带你了解超级蓝钻和豪华蓝的区别
2022/09/15
相关教程
更多>-
传奇分身术脚本 天堂w搬砖辅助
2022/11/28 -
脚本错误是怎么回事 我的电脑经常出现''脚本错误''是怎么回事
2022/11/27 -
洛克王国技能石辅助 洛克王国:最强的4大辅助宠物,丝血都被救回,水王已经迟暮
2022/11/28 -
传奇狂刀辅助免费版 传奇永恒狂刀辅助免费版 v2.85
2022/11/27 -
液压系统的辅助元件 【专题】液压系统学习专题-第五节:辅助元件(1)
2022/11/27 -
python网页自动化脚本 selenium python 实现基本自动化测试的示例代码
2022/11/28 -
龙之牧场辅助 2021年该玩什么,Jump都帮你整理好了!
2022/11/27 -
虚拟机 m dos 脚本 开源虚拟机(Oracle VM VirtualBox) v7.0
2022/11/28 -
新天龙八部至尊宝脚本怎么用 新天龙八部(永恒经典版)
2022/11/28 -
视听说刷分脚本f12 [更新]智慧树刷课脚本(js)解放你的双手(1.5倍速率)
2023/03/15 -
shell脚本编程实例 shell脚本速成
2022/11/28 -
梦三国梦逍遥辅助 逍遥三国下载
2022/11/28 -
nmap漏洞扫描脚本 2022年全球白帽常用工具排行榜TOP 10
2022/11/28 -
日女辅助符文天赋 一本上分心经 操作意识好不如良好心态
2023/03/15 -
手游时空猎人辅助 时空猎人qq版-时空猎人无限攻击辅助免费版
2022/11/28