drf API 接口默认返回的只是数据的JSON字符串,不包含其它的接口信息,甚至有时候格式也不一致,这对前端不太友好,因此我但愿把这个返回修改一下,往返回信息里面添加一些额外的信息,如状态,说明等信息前端
首先,要知道在哪里修改这个返回,翻一下源码发现这些返回信息是写在create()、list()、retrieve()、update()、destroy()这些方法里的,这些信息都放在Response对象里面返回到前端页面去。python
{'code': 1, 'msg': '成功', 'errors': {}, 'data': []} # errors 放具体的错误信息,data 放返回去的数据spa
而后用这个 dict 直接替换 Response 里面的信息就好了,以下:3d
替换后,尝试请求下接口,默认的返回格式就变成咱们定义的样子了,可是,任务还没完成,在只有一个接口的状况下,这样改改没什么,可是若是有十几个,几十个接口的话,这样一个个接口去改,不但累人还很差维护,因此这里换种方法。调试
咱们经过定义一个继承于 ModelViewSet 的类,而后全部的接口再也不继承 ModelViewSet 而继承于这个 CustomViewSet
,这就不用一个个接口去改了,还方便维护。rest
到此为止,任务依然没有完成,成功的返回咱们是定义好了,可是接口发生异常的时候,返回的信息仍是默认的那些信息,由于咱们改的只是正常处理完成后的成功返回,异常返回咱们是没有处理,那异常信息的返回应该在哪里改?code
一顿调试后,我发现了当接口发生异常后,是由exception_handler
这个方法去处理的。这个方法定义在rest_framework/views.py
里,由于这个方法是独立出来的,不是定义在 ModelViewSet 里面,因此就没办法经过重写的方法来改了,咱们把整个方法复制出来,放在CustomViewSet
下面(固然没有规定要放在一块儿,放在哪里都行,方便管理就行)。cdn
能够看出,第95行到98行就是咱们须要改的地方,调试看一下这个对象是怎样的,而后进一步把里面咱们须要的信息提取出来,改为这个样子:对象
最重要的一步!要在settings.py
里面的 REST_FRAMEWORK
(本身添加的)里添加多一条这样的配置:blog
REST_FRAMEWORK = {
······
······
'EXCEPTION_HANDLER': 'common.views.exception_handler'
}
复制代码
这里指定了使用哪一个方法做为接口异常的处理器,这个设置成咱们刚刚改那个。
PS: 虽然作了上面的修改后,就修改了系统上大部分的返回信息,可是有时候咱们须要定一个接口不是继承 ModelViewSet 的,这样这些修改就不能继承到了,在这样的状况下,每写一次接口,都要本身手动敲一遍这些信息,不免会手快敲错了,在这里我定义了一个类:
那上面的接口就能够改为这个样子了,更加的方便维护:
ModelViewSet
的类,重写create、list、update、retrieve、destroy这些方法,修改Responserest_framework/views.py/exception_handler
方法,修改里面处理异常信息的代码settings.py
的REST_FRAMEWORK
配置里面添加'EXCEPTION_HANDLER': 'common.views.exception_handler'
ResturnMsg
,代替手动写返回信息,避免错误。