Django:设置为30秒后过期的Cookie实际上是30分钟后过期的?

2024-04-29 17:06:36 发布

您现在位置:Python中文网/ 问答频道 /正文

这是我的代码:

def update_session(request):
    if not request.is_ajax() or not request.method=='POST':
       return HttpResponseNotAllowed(['POST'])
    user_id = request.POST.get('u')
    hr = set_terminal_cookie(user_id)
    return hr

def set_terminal_cookie(user_id):
    print 'set_terminal_cookie'
    hr = HttpResponse('ok')
    print datetime.datetime.now()
    expiry_time = datetime.datetime.now() + datetime.timedelta(seconds=30)
    print expiry_time
    hr.set_cookie('user_id', user_id, expiry_time)
    return hr 

这是日志输出:

set_terminal_cookie
2011-04-05 23:16:36.706624
2011-04-05 23:17:06.706806

但是,如果我在Firefox中检查“user_id”cookie,则“Expires”日期为:

Tue Apr 5 23:50:07 2011

我做错什么了?


Tags: iddatetimereturntimecookierequestdefhr
3条回答

您可以在数秒内使用max_age参数,而不是使用expires;它将为您计算expires。您的datetime.now()的问题可能是您没有使用UTC(您可以使用datetime.utcnow())。

hr.set_cookie('user_id', user_id, max_age=30)

故事的寓意是:read the documentation;它解释了需要使用UTCdatetime对象,并描述了max_age

对于那些在使用签名cookie时遇到相同问题的用户,必须将^{}max_age属性一起使用。我尝试用^{}方法设置它,但是当再次获取它时,这不起作用。

所以这不会使你的cookie过期:

cookie_max_age = settings.TWO_FACTOR_REMEMBER_USER_SECONDS
response.set_signed_cookie('key', max_age=cookie_max_age)

但当按如下方式获取时,它应该可以工作(在cookie上设置和不设置max_age):

cookie_max_age = 3600
cookie = request.get_signed_cookie('key', max_age=cookie_max_age)

请改为:

hr.set_cookie('user_id', user_id, max_age=30)

max_age参数是希望cookie持续的秒数。

相关问题 更多 >