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 查看設置完畢的效果:
爲方便使用,可以自定義方法, 智能設置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/