我想在我的Django應用程序中登錄用戶IP地址,特別是登錄,註銷和登錄失敗事件。我使用Django的內置功能如下:Django登錄user_login_failed信號的用戶IP
from django.contrib.auth.signals import user_logged_in, user_logged_out, user_login_failed
from ipware.ip import get_ip
import logging
logger = logging.getLogger(__name__)
def log_logged_in(sender, user, request, **kwargs):
logger.info("%s User %s successfully logged in" % (get_ip(request), user))
def log_logged_out(sender, user, request, **kwargs):
logger.info("%s User %s successfully logged out" % (get_ip(request), user))
def log_login_failed(sender, credentials, **kwargs):
logger.warning("%s Authentication failure for user %s" % ("...IP...", credentials['username']))
user_logged_in.connect(log_logged_in)
user_logged_out.connect(log_logged_out)
user_login_failed.connect(log_login_failed)
的問題是,我還沒有找到一種方式來獲得的IP爲user_login_failed
信號,因爲這個功能沒有在參數request
(https://docs.djangoproject.com/en/1.7/ref/contrib/auth/#module-django.contrib.auth.signals) 。 credentials
參數是僅包含username
和password
字段的字典。
我怎樣才能得到這個信號的IP地址?
非常感謝您的幫助。