-
Notifications
You must be signed in to change notification settings - Fork 41
/
Copy pathget__post.py
59 lines (48 loc) · 1.84 KB
/
get__post.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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
"""
Tutorial - Passing variables
This tutorial shows you how to pass GET/POST variables to methods.
"""
# SOURCE: https://github.com/cherrypy/cherrypy/blob/master/cherrypy/tutorial/tut03_get_and_post.py
import cherrypy
class WelcomePage:
@cherrypy.expose
def index(self):
# Ask for the user's name.
return """
<p>GET:<p>
<form action="greet_user" method="GET">
What is your name?
<input type="text" name="name" />
<input type="submit" />
</form>
<br>
<p>POST:<p>
<form action="greet_user" method="POST">
What is your name?
<input type="text" name="name" />
<input type="submit" />
</form>
"""
@cherrypy.expose
def greet_user(self, name=None):
# CherryPy passes all GET and POST variables as method parameters.
# It doesn't make a difference where the variables come from, how
# large their contents are, and so on.
#
# You can define default parameter values as usual. In this
# example, the "name" parameter defaults to None so we can check
# if a name was actually specified.
if name:
# Greet the user!
return "Hey %s, what's up?" % name
else:
if name is None:
# No name was specified
return 'Please enter your name <a href="./">here</a>.'
else:
return 'No, really, enter your name <a href="./">here</a>.'
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(WelcomePage())