使用Django的post_save()信号

4 投票
1 回答
7518 浏览
提问于 2025-04-16 14:38

我有两个表:

class Advertisement(models.Model):
    created_at = models.DateTimeField(auto_now_add=True)
    author_email = models.EmailField()

class Verification(models.Model):
    advertisement = models.ForeignKeyField(Advertisement)
    key = models.CharField(max_length=32)

我需要在添加新广告后,自动填充验证表。

def gen_key(sender, instance, created, **kwargs):
    if created:
        from hashlib import md5
        vkey = md5("%s%s" % (instance.author_email, instance.created_at))
        ver = Verification(advertisement=instance)
        ver.key = vkey
        ver.save()

post_save.connect(gen_key, sender=Advertisement)

当然,这样做是行不通的。使用的是Django 1.2版本。
问:我该怎么做呢?


好吧,问题部分解决了。
问题在于,父模型的post_save()方法没有调用子模型的post_save()。
所以你可以通过直接提供子类来解决这个问题。

class Advertisement(models.Model):
    created_at = models.DateTimeField(auto_now_add=True)
    author_email = models.EmailField()

class Sale(Advertisement):
    rooms = models.IntegerField(max_length=1)
    subway = models.ForeignKey(Subway)

class Verification(models.Model):
    advertisement = models.ForeignKeyField(Advertisement)
    key = models.CharField(max_length=32)

def gen_key(sender, instance, created, **kwargs):
    code goes here
post_save.connect(gen_key, sender=Sale, dispatch_uid="my_unique_identifier")

接下来的问题是:“我该如何在post_save()中使用父类?”

1 个回答

5

与其连接到一个特定的发送者,不如直接连接到 post_save 这个事件,然后在你的处理函数中检查保存的实例的类型,比如:

def gen_key(sender, **kwargs):
    if issubclass(sender, Advertisement):
        code goes here
post_save.connect(gen_key, dispatch_uid="my_unique_identifier")

撰写回答