Wis*_*ill 5 python django rest django-signals django-allauth
我有一个使用 djangorest auth 的 djangorest 应用程序。我试图在每次用户使用信号登录时记录一些内容。
我在网上搜索了如何使用信号,但没有找到任何关于如何使其发挥作用的有趣材料。我认为问题可能出在 allauth 信号上。下面的配置有问题吗?
信号.py
import logging
from allauth.account.signals import user_logged_in
from django.dispatch import receiver
logger = logging.getLogger(__name__)
@receiver(user_logged_in)
def login_logger(request, user, **kwargs):
    logger.info("{} logged in with {}".format(user.email, request))
Run Code Online (Sandbox Code Playgroud)
应用程序.py
from django.apps import AppConfig
class UsersConfig(AppConfig):
    name = 'users'
    def ready(self):
        import users.signals
Run Code Online (Sandbox Code Playgroud)
__init__.py
default_app_config = 'users.apps.UsersConfig'
Run Code Online (Sandbox Code Playgroud)
    rob*_*sco 10
这是我使用以下方法解决它的方法djangorestframework-jwt==1.11.0:
设置.py
from django.contrib.auth.signals import user_logged_in
def jwt_response_payload_handler(token, user=None, request=None):
    if user and request:
        user_logged_in.send(sender=user.__class__, request=request, user=user)
    return {
        'token': token,
    }
JWT_AUTH = {
    'JWT_RESPONSE_PAYLOAD_HANDLER': jwt_response_payload_handler,
}
Run Code Online (Sandbox Code Playgroud)
模型.py
from django.contrib.auth.signals import user_logged_in
def login_handler(sender, user, request, **kwargs):
    print('logged in')
user_logged_in.connect(login_handler)
Run Code Online (Sandbox Code Playgroud)
        |   归档时间:  |  
           
  |  
        
|   查看次数:  |  
           11214 次  |  
        
|   最近记录:  |