Tastypie APIKey身份验证

Chr*_*r H 12 django api-key tastypie

Tastypie APIKey身份验证如何工作?我知道文档中提到了一个信号:

from django.contrib.auth.models import User    
from django.db import models  
from tastypie.models import create_api_key 

models.signals.post_save.connect(create_api_key, sender=User)
Run Code Online (Sandbox Code Playgroud)

但是,什么时候被称为?如果我想向用户提供他们的API密钥,我知道我可以在APIKey数据库中找到这个create_api_key函数添加密钥,但是在何时何地调用此models.signals.post_save函数?

这只是另一款django型号吗?我觉得是这样的?

每次保存用户帐户时都会调用此命令吗?

K Z*_*K Z 18

您可以将其放在models.py相关应用程序的文件中(例如main/).什么post_save.connect(create_api_key, sender=User)做的是,每次一个User实例被保存,create_api_key()将被调用.

现在让我们来看看create_api_key()通过潜入tastypie来源会有什么影响:

class ApiKey(models.Model):
    user = models.OneToOneField(User, related_name='api_key')
    key = models.CharField(max_length=256, blank=True, default='')
    created = models.DateTimeField(default=datetime.datetime.now)

    def __unicode__(self):
        return u"%s for %s" % (self.key, self.user)

    def save(self, *args, **kwargs):
        if not self.key:
            self.key = self.generate_key()

        return super(ApiKey, self).save(*args, **kwargs)

    def generate_key(self):
        # Get a random UUID.
        new_uuid = uuid.uuid4()
        # Hmac that beast.
        return hmac.new(str(new_uuid), digestmod=sha1).hexdigest()


def create_api_key(sender, **kwargs):
    """
    A signal for hooking up automatic ``ApiKey`` creation.
    """
    if kwargs.get('created') is True:
        ApiKey.objects.create(user=kwargs.get('instance'))
Run Code Online (Sandbox Code Playgroud)

如您所见,create_api_key()将创建一条ApiKey与呼叫相关的新记录User.该记录在保存到表格时也会有一个HMAC密钥ApiKey.密钥由generate_key()函数生成.