Бастиан, я объясняю тебе мой шаблонный код, надеюсь, это поможет тебе:
Начиная с django 1.2, он может написать проверочный код на модели . Когда мы работаем с формами модели, instance.full_clean () вызывается при проверке формы.
В каждой модели я перезаписываю clean()
метод пользовательской функцией (этот метод автоматически вызывается из full_clean () при проверке формы модели):
from django.db import models
class Issue(models.Model):
....
def clean(self):
rules.Issue_clean(self) #<-- custom function invocation
from issues import rules
rules.connect()
Затем в файле rules.py
я пишу правила для бизнеса. Также я подключаю pre_save()
к своей пользовательской функции, чтобы предотвратить сохранение модели с неправильным состоянием:
из Issues.Models Import Issue
def connect():
from django.db.models.signals import post_save, pre_save, pre_delete
#issues
pre_save.connect(Issue_pre_save, sender = Incidencia )
post_save.connect(Issue_post_save, sender = Incidencia )
pre_delete.connect(Issue_pre_delete, sender= Incidencia)
def Incidencia_clean( instance ): #<-- custom function
import datetime as dt
errors = {}
#dia i hora sempre informats
if not instance.dia_incidencia: #<-- business rules
errors.setdefault('dia_incidencia',[]).append(u'Data missing: ...')
#dia i hora sempre informats
if not instance.franja_incidencia:
errors.setdefault('franja_incidencia',[]).append(u'Falten Dades: ...')
#Només es poden posar incidències més ennlà de 7 dies
if instance.dia_incidencia < ( dt.date.today() + dt.timedelta( days = -7) ):
errors.setdefault('dia_incidencia 1',[]).append(u'''blah blah error desc)''')
#No incidències al futur.
if instance.getDate() > datetime.now():
errors.setdefault('dia_incidencia 2',[]).append(u'''Encara no pots ....''')
...
if len( errors ) > 0:
raise ValidationError(errors) #<-- raising errors
def Issue_pre_save(sender, instance, **kwargs):
instance.clean() #<-- custom function invocation
Затем modelform вызывает метод clean модели и моя функция custon проверяет правильное состояние или выдает ошибку, которая обрабатывается формой модели.
Для отображения ошибок в форме, вы должны включить это в шаблон формы:
{% if form.non_field_errors %}
{% for error in form.non_field_errors %}
{{error}}
{% endfor %}
{% endif %}
Причина в том, что ошибки проверки модели связаны с записью словаря ошибок non_field_errors.
Когда вы сохраняете или удаляете модель из формы, вы должны помнить, что может возникнуть ошибка:
try:
issue.delete()
except ValidationError, e:
import itertools
errors = list( itertools.chain( *e.message_dict.values() ) )
Кроме того, вы можете добавлять ошибки в словарь форм без моделей:
try:
#provoco els errors per mostrar-los igualment al formulari.
issue.clean()
except ValidationError, e:
form._errors = {}
for _, v in e.message_dict.items():
form._errors.setdefault(NON_FIELD_ERRORS, []).extend( v )
Помните, что этот код не выполняется для метода save (): обратите внимание, что full_clean () не будет вызываться автоматически при вызове метода save () вашей модели или в результате проверки ModelForm. Затем вы можете добавить ошибки в словарь форм на без моделей :
try:
#provoco els errors per mostrar-los igualment al formulari.
issue.clean()
except ValidationError, e:
form._errors = {}
for _, v in e.message_dict.items():
form._errors.setdefault(NON_FIELD_ERRORS, []).extend( v )