-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathsessions.py
41 lines (30 loc) · 1.22 KB
/
sessions.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
"""
Tutorial - Sessions
Storing session data in CherryPy applications is very easy: cherrypy
provides a dictionary called "session" that represents the session
data for the current user. If you use RAM based sessions, you can store
any kind of object into that dictionary; otherwise, you are limited to
objects that can be pickled.
"""
# SOURCE: https://github.com/cherrypy/cherrypy/blob/master/cherrypy/tutorial/tut07_sessions.py
import cherrypy
class HitCounter:
_cp_config = {"tools.sessions.on": True}
@cherrypy.expose
def index(self):
# Increase the silly hit counter
count = cherrypy.session.get("count", 0) + 1
# Store the new value in the session dictionary
cherrypy.session["count"] = count
# And display a silly hit count message!
return (
f"""
During your current session, you've viewed this
page {count} times! Your life is a patio of fun!
"""
)
if __name__ == "__main__":
# CherryPy always starts with app.root when trying to map request URIs
# to objects, so we need to mount a request handler root. A request
# to '/' will be mapped to HelloWorld().index().
cherrypy.quickstart(HitCounter())