反序列化优化:校验前端参数
之前的代码中,因为太繁琐,就省略了对前端传递的参数进行正确性校验。在这里,我们对这部分进行优化
- 调用序列化器对象的
is_valid
方法,校验前端参数的正确性
- 校验成功返回True
- 校验失败返回False
serializer.is_vaild(raise_exception = True)
- 校验失败会抛出异常
- 当调用is_valid()方法后,就可以调用serializer.errors属性,抛出dict格式的错误信息
看一个新增项目的例子:
def post(self,request):
#新增项目
# 1.获取请求中body的值,并解码
json_data = request.body.decode('utf-8')
#2.反序列化成dict
python_data= json.loads(json_data,encoding='utf-8')
#3.序列化前端传来的参数,为了得到模型类对象,注意需要使用data接受dict
ser = ProjectsSerializer(data=python_data)
# 4.校验传递的参数是否符合规则
try:
ser.is_valid(raise_exception=True) # 不符合规则则抛出错误
except Exception as e:
return JsonResponse(ser.errors) ## 返回序列化器原有的dict类型的错误信息
#5.创建数据,注意这里传的值为序列化验证后的值
project = Projects.objects.create(**ser.validated_data)
#6.序列化新创建的数据
ser = ProjectsSerializer(project)
#7.返回
return JsonResponse(ser.data, safe=False)
传入空值:会有错误提示
此时应该是可以校验是否为空,长度,数