django - Tastypie APIKey 认证

标签 django tastypie api-key

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)

然而,这是什么时候调用的?如果我想给用户他们的 APIkey,我知道我可以在 APIKey 数据库中找到它,这个 create_api_key 函数将 key 添加到其中,但是我在哪里以及何时调用这个 models.signals.post_save 函数?

这只是另一个 Django 模型吗?我认为是吗?

每次保存用户帐户时都会调用它吗?

最佳答案

你可以把它放在 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'))

如您所见,create_api_key()将创建一个新的 ApiKey记录,这将与调用 User 相关.这条记录也会有 HMAC保存到 ApiKey 时的 key 表。 key 由 generate_key() 生成功能。

关于django - Tastypie APIKey 认证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12485053/

相关文章:

python - Django Tastypie 使用 PATCH 或 PUT 请求进行多对多( self )字段更新?

ios - 使用 Twitter 在 iPhone 中登录用户并将经过身份验证的用户保存到远程 Django 应用程序

heroku - 我应该如何在heroku上存储我的api key ,以便它仍然保密,而不是嵌入网页代码中

django - 将基于类的通用 View DetailView 与 ModelForm 一起使用揭示了一个错误 - 如何继续?

Django createview 使用主键

python - Django 日期时间声明错误

django - 使用 PyMongo 作为 Django 后端

android - 在 Play 商店中发布 apk 后,Google map 显示灰色方 block

git - 当我推送到 GitHub 时如何处理 secret API key ,以便我的项目在克隆 repo 协议(protocol)时仍然有效?

javascript - 为什么我不能提醒这个从 django render_to_response 返回的字符串