事情是这样的,我有一个守护进程,不停地从 RabbitMQ 消费数据,然后保存到 MySQL。操作数据库使用的是 Django 的 ORM 语法。
最近一段时间,频繁发生一个问题,就是有一类数据,守护进程从后台使用 create
方法,直接入库完全没问题。但是,在页面上,通过表单来修改这条数据,无论如何都无法保存成功,报错信息提示某一个字段不能为空。但是这个字段明明是有值的,很让人费解。
仔细分析了代码之后,感觉可能发生问题的只有这一句:
serializer = self.get_serializer(data=request.data)
serializer.is_valid(raise_exception=True)
因为打印 serializer
是有值的,所以肯定是 is_valid
做表单验证时给过滤掉了。但是为什么会过滤就需要更深一步去探索了。
通过单步调试,走到函数的调用关系中,发现了问题的关键所在。
```python
# django/forms/fields.py
class CharField(Field):
def __init__(self, *, max_length=None, min_length=None, strip=True, empty_value='', **kwargs):
self.max_length = max_length