Django設置Cookie的過期時間expires, max_age的格式

cookie中 max_age和expires的關係:

1. 若沒有填寫 max_age, expires ,默認都爲None
    此時該cooike爲臨時的,只存在瀏覽器內存中, 關閉瀏覽器則自動刪除
2. 只有max_age,  則按秒計算過期時間, 瀏覽器會存在本地緩存路徑, 並自動刪除過期cookie
3. 只有expires,  則按照時間字符串計算過期時間, 瀏覽器會存在本地緩存路徑, 自動刪除過期cookie
3. 若 max_age和 expires 同時存在,  則默認使用 max_age
4. 如果設置的cookie時間小於計算機時間, 瀏覽器則不提取cookie

max_age 格式:

max_age = 60*60*24   #按秒計算

expires 格式:

epires格式可以爲:
    1.時間格式的字符串 : " Wdy, DD-Mth-YY HH:MM:SS GMT " 
    2.秒數
    3.datetime.datetime 對象
例:
expires = 'Thu, 28-May-2020 08:53:06 GMT'       # 24小時 格林威治時間
expires = datetime.datetime(2020, 5, 28, 23, 44, 55))
expires = 60 * 60 * 24

通過Chrome 查看設置完畢的效果:

Django設置Cookie的過期時間expires, max_age的格式
Django設置Cookie的過期時間expires, max_age的格式


爲方便使用,可以自定義方法, 智能設置expires的過期時間

from django.conf import settings
import datetime

def set_cookie(response, key, value, expire=None):
    if expire is None:
        max_age = 365*24*60*60  #默認max_age爲一年, 如果存在expires,則覆蓋max_age
    else:
        max_age = expire
    expires = datetime.datetime.strftime(datetime.datetime.utcnow() + datetime.timedelta(seconds=max_age), "%a, %d-%b-%Y %H:%M:%S GMT")
    response.set_cookie(key, value, max_age=max_age, expires=expires, 
    domain=settings.SESSION_COOKIE_DOMAIN, secure=settings.SESSION_COOKIE_SECURE or None)

本文參考並總結: https://www.djangosnippets.org/snippets/40/

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章