summaryrefslogtreecommitdiff
path: root/docs/topics/http
diff options
context:
space:
mode:
authorPreetham Nosum <vpnosum@gmail.com>2016-07-21 13:39:13 -0400
committerTim Graham <timograham@gmail.com>2016-07-22 17:16:19 -0400
commit32cf01c1c1dcd5fa5d700d0e5117778caf947b74 (patch)
treea022a712372f14c6bd25f5dc4cd9d6d5dbf8c60d /docs/topics/http
parentdde6288fbe97c7053e67b613fec3366f3c298cf4 (diff)
downloaddjango-32cf01c1c1dcd5fa5d700d0e5117778caf947b74.tar.gz
Fixed #18348 -- Documented SesssionStore.create()
Diffstat (limited to 'docs/topics/http')
-rw-r--r--docs/topics/http/sessions.txt10
1 files changed, 8 insertions, 2 deletions
diff --git a/docs/topics/http/sessions.txt b/docs/topics/http/sessions.txt
index bf1248e787..0b48853bba 100644
--- a/docs/topics/http/sessions.txt
+++ b/docs/topics/http/sessions.txt
@@ -487,14 +487,20 @@ An API is available to manipulate session data outside of a view::
>>> s = SessionStore()
>>> # stored as seconds since epoch since datetimes are not serializable in JSON.
>>> s['last_login'] = 1376587691
- >>> s.save()
+ >>> s.create()
>>> s.session_key
'2b1189a188b44ad18c35e113ac6ceead'
-
>>> s = SessionStore(session_key='2b1189a188b44ad18c35e113ac6ceead')
>>> s['last_login']
1376587691
+``SessionStore.create()`` is designed to create a new session (i.e. one not
+loaded from the session store and with ``session_key=None``). ``save()`` is
+designed to save an existing session (i.e. one loaded from the session store).
+Calling ``save()`` on a new session may also work but has a small chance of
+generating a ``session_key`` that collides with an existing one. ``create()``
+calls ``save()`` and loops until an unused ``session_key`` is generated.
+
If you're using the ``django.contrib.sessions.backends.db`` backend, each
session is just a normal Django model. The ``Session`` model is defined in
``django/contrib/sessions/models.py``. Because it's a normal model, you can