Beruflich Dokumente
Kultur Dokumente
Audience
This tutorial has been prepared for anyone who has a basic knowledge of
Python and has an urge to develop websites. After completing this tutorial,
you will find yourself at a moderate level of expertise in developing
websites using Flask.
Prerequisites
Before you start proceeding with this tutorial, we are assuming that you
have hands-on experience on HTML and Python. If you are not well aware
of these concepts, then we will suggest you to go through our short
tutorials on HTML and Python.
Flask – Overview
What is Web Framework?
Web Application Framework or simply Web Framework represents a
collection of libraries and modules that enables a web application
developer to write applications without having to bother about low-level
details such as protocols, thread management etc.
What is Flask?
Flask is a web application framework written in Python. It is developed
by Armin Ronacher, who leads an international group of Python
enthusiasts named Pocco. Flask is based on the Werkzeug WSGI toolkit
and Jinja2 template engine. Both are Pocco projects.
WSGI
Web Server Gateway Interface (WSGI) has been adopted as a standard
for Python web application development. WSGI is a specification for a
universal interface between the web server and the web applications.
Werkzeug
It is a WSGI toolkit, which implements requests, response objects, and
other utility functions. This enables building a web framework on top of it.
The Flask framework uses Werkzeug as one of its bases.
Jinga2
Jinga2 is a popular templating engine for Python. A web templating system
combines a template with a certain data source to render dynamic web
pages.
Flask is often referred to as a micro framework. It aims to keep the core
of an application simple yet extensible. Flask does not have built-in
abstraction layer for database handling, nor does it have form a validation
support. Instead, Flask supports the extensions to add such functionality
to the application. Some of the popular Flask extensions are discussed
later in the tutorial.
Flask – Environment
Prerequisite
Python 2.6 or higher is usually required for installation of Flask. Although
Flask and its dependencies work well with Python 3 (Python 3.3 onwards),
many Flask extensions do not support it properly. Hence, it is
recommended that Flask should be installed on Python 2.7.
The above command can be run directly, without virtual environment for
system-wide installation.
Flask – Application
In order to test Flask installation, type the following code in the editor
as Hello.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
if __name__ == '__main__':
app.run()
1 host
Hostname to listen on. Defaults to 127.0.0.1 (localhost). Set to ‘0.0.0.0’
to have server available externally
2 port
Defaults to 5000
3 debug
4 Options
Debug mode
A Flask application is started by calling the run() method. However,
while the application is under development, it should be restarted manually
for each change in the code. To avoid this inconvenience, enable debug
support. The server will then reload itself if the code changes. It will also
provide a useful debugger to track the errors if any, in the application.
The Debug mode is enabled by setting the debug property of
the application object to True before running or passing the debug
parameter to the run() method.
app.debug = True
app.run()
app.run(debug = True)
Flask – Routing
Modern web frameworks use the routing technique to help a user
remember application URLs. It is useful to access the desired page directly
without having to navigate from the home page.
The route() decorator in Flask is used to bind URL to a function. For
example −
@app.route(‘/hello’)
def hello_world():
app = Flask(__name__)
@app.route('/hello/<name>')
def hello_name(name):
if __name__ == '__main__':
app.run(debug = True)
Save the above script as hello.py and run it from Python shell. Next, open
the browser and enter URL http://localhost:5000/hello/Python.
The following output will be displayed in the browser.
Hello Python!
In addition to the default string variable part, rules can be constructed
using the following converters −
1 int
accepts integer
2 float
3 path
app = Flask(__name__)
@app.route('/blog/<int:postID>')
def show_blog(postID):
@app.route('/rev/<float:revNo>')
def revision(revNo):
if __name__ == '__main__':
app.run()
app = Flask(__name__)
@app.route('/flask')
def hello_flask():
@app.route('/python/')
def hello_python():
if __name__ == '__main__':
app.run()
Both the rules appear similar but in the second rule, trailing slash (/) is
used. As a result, it becomes a canonical URL. Hence,
using /python or /python/returns the same output. However, in case of
the first rule, /flask/ URL results in 404 Not Found page.
app = Flask(__name__)
@app.route('/admin')
def hello_admin():
@app.route('/guest/<guest>')
def hello_guest(guest):
@app.route('/user/<name>')
def hello_user(name):
if name =='admin':
return redirect(url_for('hello_admin'))
else:
if __name__ == '__main__':
app.run(debug = True)
The above script has a function user(name) which accepts a value to its
argument from the URL.
The User() function checks if an argument received matches ‘admin’ or
not. If it matches, the application is redirected to
the hello_admin() function using url_for(), otherwise to
the hello_guest() function passing the received argument as guest
parameter to it.
Save the above code and run from Python shell.
Open the browser and enter URL as
− http://localhost:5000/user/admin
The application response in browser is −
Hello Admin
1 GET
2 HEAD
3 POST
Used to send HTML form data to server. Data received by POST method
is not cached by server.
4 PUT
5 DELETE
By default, the Flask route responds to the GET requests. However, this
preference can be altered by providing methods argument
to route()decorator.
In order to demonstrate the use of POST method in URL routing, first let
us create an HTML form and use the POST method to send form data to a
URL.
Save the following script as login.html
<html>
<body>
<p>Enter Name:</p>
</form>
</body>
</html>
app = Flask(__name__)
@app.route('/success/<name>')
def success(name):
def login():
if request.method == 'POST':
user = request.form['nm']
else:
user = request.args.get('nm')
if __name__ == '__main__':
app.run(debug = True)
Flask – Templates
It is possible to return the output of a function bound to a certain URL in
the form of HTML. For instance, in the following script, hello() function
will render ‘Hello World’ with <h1> tag attached to it.
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
if __name__ == '__main__':
app.run(debug = True)
app = Flask(__name__)
@app.route('/')
def index():
return render_template(‘hello.html’)
if __name__ == '__main__':
app.run(debug = True)
Flask will try to find the HTML file in the templates folder, in the same
folder in which this script is present.
• Application folder
o Hello.py
o templates
▪ hello.html
The term ‘web templating system’ refers to designing an HTML script in
which the variable data can be inserted dynamically. A web template
system comprises of a template engine, some kind of data source and a
template processor.
Flask uses jinga2 template engine. A web template contains HTML syntax
interspersed placeholders for variables and expressions (in these case
Python expressions) which are replaced values when the template is
rendered.
The following code is saved as hello.html in the templates folder.
<!doctype html>
<html>
<body>
</body>
</html>
app = Flask(__name__)
@app.route('/hello/<user>')
def hello_name(user):
if __name__ == '__main__':
app.run(debug = True)
As the development server starts running, open the browser and enter URL
as − http://localhost:5000/hello/mvl
The variable part of URL is inserted at {{ name }} place holder.
The Jinga2 template engine uses the following delimiters for escaping
from HTML.
app = Flask(__name__)
@app.route('/hello/<int:score>')
def hello_name(score):
if __name__ == '__main__':
app.run(debug = True)
<html>
<body>
{% if marks>50 %}
{% else %}
{% endif %}
</body>
</html>
Note that the conditional statements if-else and endif are enclosed in
delimiter {%..%}.
Run the Python script and visit URL http://localhost/hello/60 and
then http://localhost/hello/30 to see the output of HTML changing
conditionally.
The Python loop constructs can also be employed inside the template. In
the following script, the result() function sends a dictionary object to
template results.html when URL http://localhost:5000/result is
opened in the browser.
The Template part of result.html employs a for loop to render key and
value pairs of dictionary object result{} as cells of an HTML table.
Run the following code from Python shell.
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/result')
def result():
dict = {'phy':50,'che':60,'maths':70}
if __name__ == '__main__':
app.run(debug = True)
<html>
<body>
<tr>
</tr>
{% endfor %}
</table>
</body>
</html>
Here, again the Python statements corresponding to the For loop are
enclosed in {%..%} whereas, the expressions key and value are put
inside {{ }}.
After the development starts running,
open http://localhost:5000/result in the browser to get the following
output.
Flask – Static Files
A web application often requires a static file such as a javascript file or
a CSSfile supporting the display of a web page. Usually, the web server is
configured to serve them for you, but during the development, these files
are served from static folder in your package or next to your module and
it will be available at /static on the application.
A special endpoint ‘static’ is used to generate URL for static files.
In the following example, a javascript function defined in hello.js is
called on OnClick event of HTML button in index.html, which is rendered
on ‘/’ URL of the Flask application.
from flask import Flask, render_template
app = Flask(__name__)
@app.route("/")
def index():
return render_template("index.html")
if __name__ == '__main__':
app.run(debug = True)
<head>
<body>
</body>
</html>
alert("Hello World")
• args − parsed contents of query string which is part of URL after question mark (?).
app = Flask(__name__)
@app.route('/')
def student():
return render_template('student.html')
def result():
if request.method == 'POST':
result = request.form
if __name__ == '__main__':
app.run(debug = True)
<body>
</form>
</body>
</html>
<html>
<body>
<tr>
</tr>
{% endfor %}
</table>
</body>
</html>
Run the Python script and enter the URL http://localhost:5000/ in the
browser.
def index():
return render_template('index.html')
<body>
<p><h3>Enter userID</h3></p>
</form>
</body>
</html>
The Form is posted to ‘/setcookie’ URL. The associated view function sets
a Cookie name userID and renders another page.
@app.route('/setcookie', methods = ['POST', 'GET'])
def setcookie():
if request.method == 'POST':
user = request.form['nm']
resp = make_response(render_template('readcookie.html'))
resp.set_cookie('userID', user)
return resp
def getcookie():
name = request.cookies.get('userID')
def index():
if 'username' in session:
username = session['username']
def login():
if request.method == 'POST':
session['username'] = request.form['username']
return redirect(url_for('index'))
return '''
</form>
'''
def logout():
session.pop('username', None)
return redirect(url_for('index'))
Run the application and visit the homepage. (Ensure to set secret_key of
the application)
from flask import Flask, session, redirect, url_for, escape, request
app = Flask(__name__)
The output will be displayed as shown below. Click the link “click here to
log in”.
The link will be directed to another screen. Type ‘admin’.
• HTTP_300_MULTIPLE_CHOICES
• HTTP_301_MOVED_PERMANENTLY
• HTTP_302_FOUND
• HTTP_303_SEE_OTHER
• HTTP_304_NOT_MODIFIED
• HTTP_305_USE_PROXY
• HTTP_306_RESERVED
• HTTP_307_TEMPORARY_REDIRECT
The default status code is 302, which is for ‘found’.
In the following example, the redirect() function is used to display the
login page again when a login attempt fails.
from flask import Flask, redirect, url_for, render_template, request
app = Flask(__name__)
@app.route('/')
def index():
return render_template('log_in.html')
def login():
request.form['username'] == 'admin' :
return redirect(url_for('success'))
return redirect(url_for('index'))
@app.route('/success')
def success():
if __name__ == '__main__':
app.run(debug = True)
Let us make a slight change in the login() function in the above code.
Instead of re-displaying the login page, if ‘Unauthourized’ page is to be
displayed, replace it with call to abort(401).
from flask import Flask, redirect, url_for, render_template, request, abort
app = Flask(__name__)
@app.route('/')
def index():
return render_template('log_in.html')
def login():
if request.method == 'POST':
if request.form['username'] == 'admin' :
return redirect(url_for('success'))
else:
abort(401)
else:
return redirect(url_for('index'))
@app.route('/success')
def success():
app.run(debug = True)
Here,
• message parameter is the actual message to be flashed.
{% if messages %}
{{ message }}
{% endfor %}
{% endif %}
{% endwith %}
def index():
return render_template('index.html')
The link leads a user to ‘/login’ URL which displays a login form. When
submitted, the login() view function verifies a username and password
and accordingly flashes a ‘success’ message or creates ‘error’ variable.
@app.route('/login', methods = ['GET', 'POST'])
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or \
request.form['password'] != 'admin':
else:
return redirect(url_for('index'))
Login.html
<!doctype html>
<html>
<body>
<h1>Login</h1>
{% if error %}
<p><strong>Error:</strong> {{ error }}
{% endif %}
<dl>
<dt>Username:</dt>
<dd>
</dd>
<dt>Password:</dt>
</form>
</body>
</html>
Index.html
<!doctype html>
<html>
<head>
</head>
<body>
{% if messages %}
<ul>
{% endfor %}
</ul>
{% endif %}
{% endwith %}
<b>log in?</b></a></p>
</body>
</html>
Flash.py
from flask import Flask, flash, redirect, render_template, request, url_for
app = Flask(__name__)
def index():
return render_template('index.html')
def login():
error = None
if request.method == 'POST':
if request.form['username'] != 'admin' or \
request.form['password'] != 'admin':
else:
return redirect(url_for('index'))
if __name__ == "__main__":
app.run(debug = True)
After executing the above codes, you will see the screen as shown below.
When you click on the link, you will be directed to the Login page.
Enter the Username and password.
Click Login. A message will be displayed “You were successfully logged in”
.