rya*_*016 15 python django logging
我想在Django中记录所有用户登录和注销尝试.此记录应显示所有登录/注销用户的历史记录,IP地址和登录/注销时间.
该django_admin_log表似乎只记录其他模型的ADD/DELETE/CHANGE活动,而不是用户访问历史记录.我也已经签了user_logged_in,user_logged_out信号.似乎如果我将使用这些信号,我需要创建一个新表来记录所有用户登录/注销的历史记录.Django中是否有内置方法来执行此操作?还是可用的套餐?我检查了其他软件包,那些与登录尝试相关的软件包仅限制失败的尝试,但不记录成功的登录/注销.
ohr*_*rom 26
您可以连接到提供的信号:django.contrib.auth.signals
import logging
from django.contrib.auth.signals import user_logged_in, user_logged_out, user_login_failed
from django.dispatch import receiver
log = logging.getLogger(__name__)
@receiver(user_logged_in)
def user_logged_in_callback(sender, request, user, **kwargs):
# to cover more complex cases:
# http://stackoverflow.com/questions/4581789/how-do-i-get-user-ip-address-in-django
ip = request.META.get('REMOTE_ADDR')
log.debug('login user: {user} via ip: {ip}'.format(
user=user,
ip=ip
))
@receiver(user_logged_out)
def user_logged_out_callback(sender, request, user, **kwargs):
ip = request.META.get('REMOTE_ADDR')
log.debug('logout user: {user} via ip: {ip}'.format(
user=user,
ip=ip
))
@receiver(user_login_failed)
def user_login_failed_callback(sender, credentials, **kwargs):
log.warning('logout failed for: {credentials}'.format(
credentials=credentials,
))
Run Code Online (Sandbox Code Playgroud)
因此到目前为止还没有接受这个答案 - 这里有一个例子,它在模型中记录操作而不是记录:
# <your_app>/models.py
from django.db import models
from django.contrib.auth.signals import user_logged_in, user_logged_out, user_login_failed
from django.dispatch import receiver
class AuditEntry(models.Model):
action = models.CharField(max_length=64)
ip = models.GenericIPAddressField(null=True)
username = models.CharField(max_length=256, null=True)
def __unicode__(self):
return '{0} - {1} - {2}'.format(self.action, self.username, self.ip)
def __str__(self):
return '{0} - {1} - {2}'.format(self.action, self.username, self.ip)
@receiver(user_logged_in)
def user_logged_in_callback(sender, request, user, **kwargs):
ip = request.META.get('REMOTE_ADDR')
AuditEntry.objects.create(action='user_logged_in', ip=ip, username=user.username)
@receiver(user_logged_out)
def user_logged_out_callback(sender, request, user, **kwargs):
ip = request.META.get('REMOTE_ADDR')
AuditEntry.objects.create(action='user_logged_out', ip=ip, username=user.username)
@receiver(user_login_failed)
def user_login_failed_callback(sender, credentials, **kwargs):
AuditEntry.objects.create(action='user_login_failed', username=credentials.get('username', None))
Run Code Online (Sandbox Code Playgroud)
# <your_app>/admin.py
from django.contrib import admin
from models import AuditEntry
@admin.register(AuditEntry)
class AuditEntryAdmin(admin.ModelAdmin):
list_display = ['action', 'username', 'ip',]
list_filter = ['action',]
Run Code Online (Sandbox Code Playgroud)