SlideShare a Scribd company logo
Python Certification Training https://www.edureka.co/python
Agenda
Python Certification Training https://www.edureka.co/python
Agenda
Python Certification Training https://www.edureka.co/python
Agenda
Introduction 01
Introduction
to Flask
Getting Started 02
Concepts 03
Practical Approach 04
Installing and working
with Flask
Looking at code to
understand theory
Overview of all the
concepts in Flask
Python Certification Training https://www.edureka.co/python
Introduction to Flask
Python Certification Training https://www.edureka.co/python
Introduction to Flask
Open Source
Flask is a web application framework written in Python.What is Flask?
Large community for
Learners and Collaborators
Let’s get started then!
Python Certification Training https://www.edureka.co/python
Introduction to Flask
What is a Web Framework?
Life without Flask! Using Flask!
ModulesLibraries
Web Developer
Python Certification Training https://www.edureka.co/python
Introduction to Flask
Flask!!
Enthusiasts named Pocco!
Werkzeug WSGI Toolkit Jinga2 Template Engine
I’m learning Flask!
Python Certification Training https://www.edureka.co/python
Installing Flask
Python Certification Training https://www.edureka.co/python
Installation - Prerequisite
Prerequisite
I’m learning Flask!
virtualenv Virtual Python Environment builder
pip install virtualenv
Sudo apt-get install virtualenv
Python Certification Training https://www.edureka.co/python
Installation - Flask
Installation
I’m learning Flask!
Once installed, new virtual environment is created in a folder
mkdir newproj
cd newproj
virtualenv venv
To activate corresponding environment, use the following:
venvscriptsactivate
pip install Flask
Python Certification Training https://www.edureka.co/python
Flask - Application
Python Certification Training https://www.edureka.co/python
Flask - Application
Test Installation
I’m learning Flask!
Use this simple code, save it as Hello.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def hello_world():
return 'Hello World’
if __name__ == '__main__':
app.run()
Python Certification Training https://www.edureka.co/python
Flask - Application
Importing flask module in the project is mandatory!
I’m learning Flask!
Flask constructor takes name of current module (__name__) as argument
App.route(rule, options)
route() function
URL binding with the function
List of parameters to be forwarded to the underlying Rule object
Python Certification Training https://www.edureka.co/python
Flask - Application
App.run(host, port, options
Sl.no Parameter Description
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 Defaults to false. If set to true, provides a debug information
3 options To be forwarded to underlying Werkzeug server.
* Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
All these parameters are optional
Python hello.py
Python Certification Training https://www.edureka.co/python
Flask – Application
Python Certification Training https://www.edureka.co/python
Flask - Application
Debug mode
Flask application is
started by calling
run() method
How to enable Debug mode?
app.debug = True
app.run()
app.run(debug = True)
Python Certification Training https://www.edureka.co/python
Flask – Routing
Python Certification Training https://www.edureka.co/python
Flask - Routing
Route() decorator in Flask is used to bind URL to a function
@app.route(‘/hello’)
def hello_world():
return ‘hello world’
add_url_rule() function is also used to bind URL with function
Check out the following representation
def hello_world():
return ‘hello world’
app.add_url_rule(‘/’, ‘hello’, hello_world)
Python Certification Training https://www.edureka.co/python
Flask –Variable Rules
Python Certification Training https://www.edureka.co/python
Flask – Variable Rules
It is possible to build a URL dynamically!
How? By adding variable parts to the rule parameter
Consider the example
from flask import Flask
app = Flask(__name__)
@app.route('/hello/<name>')
def hello_name(name):
return 'Hello %s!' % name
if __name__ == '__main__':
app.run(debug = True)
http://localhost:5000/hello/Edureka
Python Certification Training https://www.edureka.co/python
Flask – Variable Rules
More rules can be constructed using these converters
Sl.no Parameter Description
1 int Accepts Integer
2 Float For Floating point value
3 Path
Accepts slashes used as
directory separator character
from flask import Flask
app = Flask(__name__)
@app.route('/blog/<int:postID>')
def show_blog(postID):
return 'Blog Number %d' % postID
@app.route('/rev/<float:revNo>')
def revision(revNo):
return 'Revision Number %f' % revNo
if __name__ == '__main__':
app.run()
Run the code
Visit the URL: http://localhost:5000/blog/11
Blog number 11Browser Output
http://localhost:5000/rev/1.1 Revision Number 1.100000
Python Certification Training https://www.edureka.co/python
Flask – Variable Rules
Consider the following code:
from flask import Flask
app = Flask(__name__)
@app.route('/flask')
def hello_flask():
return 'Hello Flask'
@app.route('/python/')
def hello_python():
return 'Hello Python'
if __name__ == '__main__':
app.run()
Run the code
/flask /flask/
/python /python/
Python Certification Training https://www.edureka.co/python
Flask – URL Binding
Python Certification Training https://www.edureka.co/python
Flask – URL Building
url_for() function is used for dynamically building a URL for a specific function
from flask import Flask, redirect, url_for
app = Flask(__name__)
@app.route('/admin')
def hello_admin():
return 'Hello Admin'
@app.route('/guest/<guest>')
def hello_guest(guest):
return 'Hello %s as Guest' % guest
@app.route('/user/<name>')
def hello_user(name):
if name =='admin':
return redirect(url_for('hello_admin'))
else:
return
redirect(url_for('hello_guest',guest = name))
if __name__ == '__main__':
app.run(debug = True)
http://localhost:5000/user/admin
Python Certification Training https://www.edureka.co/python
Flask – HTTP Methods
Python Certification Training https://www.edureka.co/python
Flask – HTTP Methods
HTTP Protocols are the foundation for data communication in WWW
Sl.no Method Description
1 GET Sends data in unencrypted form to server
2 HEAD Same as GET, but without response body
3 POST Used to send HTML form data to server.
4 PUT
Replaces all current representations of target resource with
uploaded content
5 DELETE
Removes all current representations of target resource given by
URL
Let’s look at an example
Python Certification Training https://www.edureka.co/python
Flask – HTTP Methods
First we look at the HTML file
<html>
<body>
<form action = "http://localhost:5000/login" method = "post">
<p>Enter Name:</p>
<p><input type = "text" name = "nm" /></p>
<p><input type = "submit" value = "submit" /></p>
</form>
</body>
</html>
Save this as login.html
Python Certification Training https://www.edureka.co/python
Flask – HTTP Methods
Next is Python Script
from flask import Flask, redirect, url_for, request
app = Flask(__name__)
@app.route('/success/<name>')
def success(name):
return 'welcome %s' % name
@app.route('/login',methods = ['POST', 'GET'])
def login():
if request.method == 'POST':
user = request.form['nm']
return redirect(url_for('success',name = user))
else:
user = request.args.get('nm')
return redirect(url_for('success',name = user))
if __name__ == '__main__':
app.run(debug = True)
Let’s check out the output!
Python Certification Training https://www.edureka.co/python
Flask – Templates
Python Certification Training https://www.edureka.co/python
Flask – Templates
Can we return the output of a function bound to a UR: in form of HTML?
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '<html><body><h1>'Hello
World'</h1></body></html>'
if __name__ == '__main__':
app.run(debug = True)
But this is cumbersome
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '<html><body><h1>'Hello
World'</h1></body></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.
Python Certification Training https://www.edureka.co/python
Flask – Templates
Flask uses jinga2 template engine
<!doctype html>
<html>
<body>
<h1>Hello {{ name }}!</h1>
</body>
</html>
Flask will try to find the HTML
file in the templates folder, in
the same folder in which this
script is present.
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/hello/<user>')
def hello_name(user):
return render_template('hello.html', name = user)
if __name__ == '__main__':
app.run(debug = True)
The Jinga2 template engine uses the following delimiters for escaping from HTML
• {% ... %} for Statements
• {{ ... }} for Expressions to print to the template output
• {# ... #} for Comments not included in the template output
• # ... ## for Line Statements
Python Certification Training https://www.edureka.co/python
Flask – Templates
Conditional statements in templates
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/hello/<int:score>')
def hello_name(score):
return render_template('hello.html', marks = score)
if __name__ == '__main__':
app.run(debug = True)
<!doctype html>
<html>
<body>
{% if marks>50 %}
<h1> Your result is pass!</h1>
{% else %}
<h1>Your result is fail</h1>
{% endif %}
</body>
</html>
HTML Template script
Python Certification Training https://www.edureka.co/python
Flask – Templates
Another example
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/result')
def result():
dict = {'phy':50,'che':60,'maths':70}
return render_template('result.html', result = dict)
if __name__ == '__main__':
app.run(debug = True)
<!doctype html>
<html>
<body>
<table border = 1>
{% for key, value in result.iteritems() %}
<tr>
<th> {{ key }} </th>
<td> {{ value }} </td>
</tr>
{% endfor %}
</table>
</body>
</html>
Python Certification Training https://www.edureka.co/python
Flask – Static Files
Python Certification Training https://www.edureka.co/python
Flask – Static Files
Web application will require a static file such as JS or CSS file
from flask import Flask, render_template
app = Flask(__name__)
@app.route('/result')
def result():
dict = {'phy':50,'che':60,'maths':70}
return render_template('result.html', result = dict)
if __name__ == '__main__':
app.run(debug = True)
<!doctype html>
<html>
<body>
<table border = 1>
{% for key, value in result.iteritems() %}
<tr>
<th> {{ key }} </th>
<td> {{ value }} </td>
</tr>
{% endfor %}
</table>
</body>
</html>
Python
function sayHello() {
alert("Hello World")
}
JS File
HTML
Python Certification Training https://www.edureka.co/python
Flask – Request Object
Python Certification Training https://www.edureka.co/python
Flask – Request Object
Data from client’s webpage is sent to server as a global request object
Form Dictionary object containing key-value pairs of form parameters and values
args Parsed contents of query string which is part of URL after question mark (?)
Cookies Dictionary object holding Cookie names and values
files Data pertaining to uploaded file
Method Current request method
Python Certification Training https://www.edureka.co/python
Flask – Cookies
Python Certification Training https://www.edureka.co/python
Flask – Cookies
Cookie is stored on client’s machine. And helps with data tracking
@app.route('/')
def index():
return render_template('index.html')
<html>
<body>
<form action = "/setcookie" method = "POST">
<p><h3>Enter userID</h3></p>
<p><input type = 'text' name = 'nm'/></p>
<p><input type = 'submit' value = 'Login'/></p>
</form>
</body>
</html>
@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
@app.route('/getcookie')
def getcookie():
name = request.cookies.get('userID')
return '<h1>welcome '+name+'</h1>'
Python Certification Training https://www.edureka.co/python
Flask – Redirect & Errors
Python Certification Training https://www.edureka.co/python
Flask – Redirect & Errors
Flask Class has a redirect() function which returns a response object
Prototype Flask.redirect(location, statuscode, response)
URL where response should be redirected
Statuscode sent to browser’s header
Response parameter used to instantiate response
Python Certification Training https://www.edureka.co/python
Flask – Redirect & Errors
Standardized status codes
Sl.no Status Code
1 HTTP_300_MULTIPLE_CHOICES
2 HTTP_301_MOVED_PERMANENTLY
3 HTTP_302_FOUND
4 HTTP_303_SEE_OTHER
5 HTTP_304_NOT_MODIFIED
6 HTTP_305_USE_PROXY
7 HTTP_306_RESERVED
Sl.no Code Description
1 400 Bad Request
2 401 Unauthenticated
3 403 Forbidden
4 404 Not Found
5 406 Not Acceptable
6 415 Unsupported Media Type
7 429 Too Many Requests
Prototype Flask.abort(code)
Python Certification Training https://www.edureka.co/python
Flask – Extensions
Python Certification Training https://www.edureka.co/python
Flask – Extensions
Flask is a micro framework
Large number of extensions
Flask Mail Flask WTF Flask SQLAlchemy Flask Sijax
Provides SMTP
interface to
Flask
application
Adds rendering
& validation of
WTForms
Adds
SQLAlchemy
support to Flask
Application
Interface for
Sijax –
Python/jQuery
library that
makes AJAX
easy to use
Extensive Documentation
Python Certification Training https://www.edureka.co/python
Conclusion
Python Certification Training https://www.edureka.co/python
Conclusion
Python Flask Tutorial For Beginners | Flask Web Development Tutorial | Python Training | Edureka

More Related Content

PPTX
Flask – Python
PPTX
Python/Flask Presentation
PPTX
PPTX
Convolution Neural Network (CNN)
PPTX
HTML Semantic Elements
PDF
Stuart russell and peter norvig artificial intelligence - a modern approach...
PPTX
Convert Hexadecimal to decimal
PPT
Learn REST API with Python
Flask – Python
Python/Flask Presentation
Convolution Neural Network (CNN)
HTML Semantic Elements
Stuart russell and peter norvig artificial intelligence - a modern approach...
Convert Hexadecimal to decimal
Learn REST API with Python

What's hot (20)

PDF
Quick flask an intro to flask
PDF
Flask Introduction - Python Meetup
PDF
Flask Basics
PPTX
Lab #2: Introduction to Javascript
PDF
Web develop in flask
PPT
Oops concepts in php
PDF
A Basic Django Introduction
PPT
Introduction to Javascript
PDF
Angular - Chapter 5 - Directives
PPTX
Angular Data Binding
PDF
Basics of JavaScript
PDF
Angular - Chapter 4 - Data and Event Handling
PPT
Java Script ppt
PPTX
Java script
PDF
3. Java Script
PPT
Ajax Ppt
PDF
Angular Observables & RxJS Introduction
PDF
Php introduction
PDF
What is REST API? REST API Concepts and Examples | Edureka
PDF
jQuery for beginners
Quick flask an intro to flask
Flask Introduction - Python Meetup
Flask Basics
Lab #2: Introduction to Javascript
Web develop in flask
Oops concepts in php
A Basic Django Introduction
Introduction to Javascript
Angular - Chapter 5 - Directives
Angular Data Binding
Basics of JavaScript
Angular - Chapter 4 - Data and Event Handling
Java Script ppt
Java script
3. Java Script
Ajax Ppt
Angular Observables & RxJS Introduction
Php introduction
What is REST API? REST API Concepts and Examples | Edureka
jQuery for beginners
Ad

Similar to Python Flask Tutorial For Beginners | Flask Web Development Tutorial | Python Training | Edureka (20)

PDF
Flask - Backend com Python - Semcomp 18
KEY
LvivPy - Flask in details
PDF
Kyiv.py #17 Flask talk
PPT
Learn flask in 90mins
PPTX
Introduction to windows power shell in sharepoint 2010
PPTX
Flask & Flask-restx
PDF
MidwestPHP 2016 - Adventures in Laravel 5
ODP
Pyramid deployment
PDF
Behavior & Specification Driven Development in PHP - #OpenWest
PPTX
Flask-RESTPlusで便利なREST API開発 | Productive RESTful API development with Flask-...
PPTX
Laravel development (Laravel History, Environment Setup & Laravel Installatio...
PPTX
Phalcon 2 - PHP Brazil Conference
ODP
CodeIgniter PHP MVC Framework
ODP
Pyramid Lighter/Faster/Better web apps
ODP
Zen and the Art of Claroline Module Development
PPTX
Phalcon - Giant Killer
PDF
What The Flask? and how to use it with some Google APIs
PPS
Simplify your professional web development with symfony
PDF
Selenium & PHPUnit made easy with Steward (Berlin, April 2017)
PPTX
SW Security Lec4 Securing architecture.pptx
Flask - Backend com Python - Semcomp 18
LvivPy - Flask in details
Kyiv.py #17 Flask talk
Learn flask in 90mins
Introduction to windows power shell in sharepoint 2010
Flask & Flask-restx
MidwestPHP 2016 - Adventures in Laravel 5
Pyramid deployment
Behavior & Specification Driven Development in PHP - #OpenWest
Flask-RESTPlusで便利なREST API開発 | Productive RESTful API development with Flask-...
Laravel development (Laravel History, Environment Setup & Laravel Installatio...
Phalcon 2 - PHP Brazil Conference
CodeIgniter PHP MVC Framework
Pyramid Lighter/Faster/Better web apps
Zen and the Art of Claroline Module Development
Phalcon - Giant Killer
What The Flask? and how to use it with some Google APIs
Simplify your professional web development with symfony
Selenium & PHPUnit made easy with Steward (Berlin, April 2017)
SW Security Lec4 Securing architecture.pptx
Ad

More from Edureka! (20)

PDF
What to learn during the 21 days Lockdown | Edureka
PDF
Top 10 Dying Programming Languages in 2020 | Edureka
PDF
Top 5 Trending Business Intelligence Tools | Edureka
PDF
Tableau Tutorial for Data Science | Edureka
PDF
Python Programming Tutorial | Edureka
PDF
Top 5 PMP Certifications | Edureka
PDF
Top Maven Interview Questions in 2020 | Edureka
PDF
Linux Mint Tutorial | Edureka
PDF
How to Deploy Java Web App in AWS| Edureka
PDF
Importance of Digital Marketing | Edureka
PDF
RPA in 2020 | Edureka
PDF
Email Notifications in Jenkins | Edureka
PDF
EA Algorithm in Machine Learning | Edureka
PDF
Cognitive AI Tutorial | Edureka
PDF
AWS Cloud Practitioner Tutorial | Edureka
PDF
Blue Prism Top Interview Questions | Edureka
PDF
Big Data on AWS Tutorial | Edureka
PDF
A star algorithm | A* Algorithm in Artificial Intelligence | Edureka
PDF
Kubernetes Installation on Ubuntu | Edureka
PDF
Introduction to DevOps | Edureka
What to learn during the 21 days Lockdown | Edureka
Top 10 Dying Programming Languages in 2020 | Edureka
Top 5 Trending Business Intelligence Tools | Edureka
Tableau Tutorial for Data Science | Edureka
Python Programming Tutorial | Edureka
Top 5 PMP Certifications | Edureka
Top Maven Interview Questions in 2020 | Edureka
Linux Mint Tutorial | Edureka
How to Deploy Java Web App in AWS| Edureka
Importance of Digital Marketing | Edureka
RPA in 2020 | Edureka
Email Notifications in Jenkins | Edureka
EA Algorithm in Machine Learning | Edureka
Cognitive AI Tutorial | Edureka
AWS Cloud Practitioner Tutorial | Edureka
Blue Prism Top Interview Questions | Edureka
Big Data on AWS Tutorial | Edureka
A star algorithm | A* Algorithm in Artificial Intelligence | Edureka
Kubernetes Installation on Ubuntu | Edureka
Introduction to DevOps | Edureka

Recently uploaded (20)

PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
PPTX
A Presentation on Artificial Intelligence
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PDF
NewMind AI Monthly Chronicles - July 2025
DOCX
The AUB Centre for AI in Media Proposal.docx
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
NewMind AI Weekly Chronicles - August'25 Week I
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
PPT
Teaching material agriculture food technology
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Electronic commerce courselecture one. Pdf
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Review of recent advances in non-invasive hemoglobin estimation
Shreyas Phanse Resume: Experienced Backend Engineer | Java • Spring Boot • Ka...
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Architecting across the Boundaries of two Complex Domains - Healthcare & Tech...
A Presentation on Artificial Intelligence
Building Integrated photovoltaic BIPV_UPV.pdf
NewMind AI Monthly Chronicles - July 2025
The AUB Centre for AI in Media Proposal.docx
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Diabetes mellitus diagnosis method based random forest with bat algorithm
Advanced methodologies resolving dimensionality complications for autism neur...
NewMind AI Weekly Chronicles - August'25 Week I
Mobile App Security Testing_ A Comprehensive Guide.pdf
The Rise and Fall of 3GPP – Time for a Sabbatical?
Teaching material agriculture food technology
Chapter 3 Spatial Domain Image Processing.pdf
Digital-Transformation-Roadmap-for-Companies.pptx
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Electronic commerce courselecture one. Pdf

Python Flask Tutorial For Beginners | Flask Web Development Tutorial | Python Training | Edureka

  • 1. Python Certification Training https://www.edureka.co/python Agenda
  • 2. Python Certification Training https://www.edureka.co/python Agenda
  • 3. Python Certification Training https://www.edureka.co/python Agenda Introduction 01 Introduction to Flask Getting Started 02 Concepts 03 Practical Approach 04 Installing and working with Flask Looking at code to understand theory Overview of all the concepts in Flask
  • 4. Python Certification Training https://www.edureka.co/python Introduction to Flask
  • 5. Python Certification Training https://www.edureka.co/python Introduction to Flask Open Source Flask is a web application framework written in Python.What is Flask? Large community for Learners and Collaborators Let’s get started then!
  • 6. Python Certification Training https://www.edureka.co/python Introduction to Flask What is a Web Framework? Life without Flask! Using Flask! ModulesLibraries Web Developer
  • 7. Python Certification Training https://www.edureka.co/python Introduction to Flask Flask!! Enthusiasts named Pocco! Werkzeug WSGI Toolkit Jinga2 Template Engine I’m learning Flask!
  • 8. Python Certification Training https://www.edureka.co/python Installing Flask
  • 9. Python Certification Training https://www.edureka.co/python Installation - Prerequisite Prerequisite I’m learning Flask! virtualenv Virtual Python Environment builder pip install virtualenv Sudo apt-get install virtualenv
  • 10. Python Certification Training https://www.edureka.co/python Installation - Flask Installation I’m learning Flask! Once installed, new virtual environment is created in a folder mkdir newproj cd newproj virtualenv venv To activate corresponding environment, use the following: venvscriptsactivate pip install Flask
  • 11. Python Certification Training https://www.edureka.co/python Flask - Application
  • 12. Python Certification Training https://www.edureka.co/python Flask - Application Test Installation I’m learning Flask! Use this simple code, save it as Hello.py from flask import Flask app = Flask(__name__) @app.route('/') def hello_world(): return 'Hello World’ if __name__ == '__main__': app.run()
  • 13. Python Certification Training https://www.edureka.co/python Flask - Application Importing flask module in the project is mandatory! I’m learning Flask! Flask constructor takes name of current module (__name__) as argument App.route(rule, options) route() function URL binding with the function List of parameters to be forwarded to the underlying Rule object
  • 14. Python Certification Training https://www.edureka.co/python Flask - Application App.run(host, port, options Sl.no Parameter Description 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 Defaults to false. If set to true, provides a debug information 3 options To be forwarded to underlying Werkzeug server. * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit) All these parameters are optional Python hello.py
  • 15. Python Certification Training https://www.edureka.co/python Flask – Application
  • 16. Python Certification Training https://www.edureka.co/python Flask - Application Debug mode Flask application is started by calling run() method How to enable Debug mode? app.debug = True app.run() app.run(debug = True)
  • 17. Python Certification Training https://www.edureka.co/python Flask – Routing
  • 18. Python Certification Training https://www.edureka.co/python Flask - Routing Route() decorator in Flask is used to bind URL to a function @app.route(‘/hello’) def hello_world(): return ‘hello world’ add_url_rule() function is also used to bind URL with function Check out the following representation def hello_world(): return ‘hello world’ app.add_url_rule(‘/’, ‘hello’, hello_world)
  • 19. Python Certification Training https://www.edureka.co/python Flask –Variable Rules
  • 20. Python Certification Training https://www.edureka.co/python Flask – Variable Rules It is possible to build a URL dynamically! How? By adding variable parts to the rule parameter Consider the example from flask import Flask app = Flask(__name__) @app.route('/hello/<name>') def hello_name(name): return 'Hello %s!' % name if __name__ == '__main__': app.run(debug = True) http://localhost:5000/hello/Edureka
  • 21. Python Certification Training https://www.edureka.co/python Flask – Variable Rules More rules can be constructed using these converters Sl.no Parameter Description 1 int Accepts Integer 2 Float For Floating point value 3 Path Accepts slashes used as directory separator character from flask import Flask app = Flask(__name__) @app.route('/blog/<int:postID>') def show_blog(postID): return 'Blog Number %d' % postID @app.route('/rev/<float:revNo>') def revision(revNo): return 'Revision Number %f' % revNo if __name__ == '__main__': app.run() Run the code Visit the URL: http://localhost:5000/blog/11 Blog number 11Browser Output http://localhost:5000/rev/1.1 Revision Number 1.100000
  • 22. Python Certification Training https://www.edureka.co/python Flask – Variable Rules Consider the following code: from flask import Flask app = Flask(__name__) @app.route('/flask') def hello_flask(): return 'Hello Flask' @app.route('/python/') def hello_python(): return 'Hello Python' if __name__ == '__main__': app.run() Run the code /flask /flask/ /python /python/
  • 23. Python Certification Training https://www.edureka.co/python Flask – URL Binding
  • 24. Python Certification Training https://www.edureka.co/python Flask – URL Building url_for() function is used for dynamically building a URL for a specific function from flask import Flask, redirect, url_for app = Flask(__name__) @app.route('/admin') def hello_admin(): return 'Hello Admin' @app.route('/guest/<guest>') def hello_guest(guest): return 'Hello %s as Guest' % guest @app.route('/user/<name>') def hello_user(name): if name =='admin': return redirect(url_for('hello_admin')) else: return redirect(url_for('hello_guest',guest = name)) if __name__ == '__main__': app.run(debug = True) http://localhost:5000/user/admin
  • 25. Python Certification Training https://www.edureka.co/python Flask – HTTP Methods
  • 26. Python Certification Training https://www.edureka.co/python Flask – HTTP Methods HTTP Protocols are the foundation for data communication in WWW Sl.no Method Description 1 GET Sends data in unencrypted form to server 2 HEAD Same as GET, but without response body 3 POST Used to send HTML form data to server. 4 PUT Replaces all current representations of target resource with uploaded content 5 DELETE Removes all current representations of target resource given by URL Let’s look at an example
  • 27. Python Certification Training https://www.edureka.co/python Flask – HTTP Methods First we look at the HTML file <html> <body> <form action = "http://localhost:5000/login" method = "post"> <p>Enter Name:</p> <p><input type = "text" name = "nm" /></p> <p><input type = "submit" value = "submit" /></p> </form> </body> </html> Save this as login.html
  • 28. Python Certification Training https://www.edureka.co/python Flask – HTTP Methods Next is Python Script from flask import Flask, redirect, url_for, request app = Flask(__name__) @app.route('/success/<name>') def success(name): return 'welcome %s' % name @app.route('/login',methods = ['POST', 'GET']) def login(): if request.method == 'POST': user = request.form['nm'] return redirect(url_for('success',name = user)) else: user = request.args.get('nm') return redirect(url_for('success',name = user)) if __name__ == '__main__': app.run(debug = True) Let’s check out the output!
  • 29. Python Certification Training https://www.edureka.co/python Flask – Templates
  • 30. Python Certification Training https://www.edureka.co/python Flask – Templates Can we return the output of a function bound to a UR: in form of HTML? from flask import Flask app = Flask(__name__) @app.route('/') def index(): return '<html><body><h1>'Hello World'</h1></body></html>' if __name__ == '__main__': app.run(debug = True) But this is cumbersome from flask import Flask app = Flask(__name__) @app.route('/') def index(): return '<html><body><h1>'Hello World'</h1></body></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.
  • 31. Python Certification Training https://www.edureka.co/python Flask – Templates Flask uses jinga2 template engine <!doctype html> <html> <body> <h1>Hello {{ name }}!</h1> </body> </html> Flask will try to find the HTML file in the templates folder, in the same folder in which this script is present. from flask import Flask, render_template app = Flask(__name__) @app.route('/hello/<user>') def hello_name(user): return render_template('hello.html', name = user) if __name__ == '__main__': app.run(debug = True) The Jinga2 template engine uses the following delimiters for escaping from HTML • {% ... %} for Statements • {{ ... }} for Expressions to print to the template output • {# ... #} for Comments not included in the template output • # ... ## for Line Statements
  • 32. Python Certification Training https://www.edureka.co/python Flask – Templates Conditional statements in templates from flask import Flask, render_template app = Flask(__name__) @app.route('/hello/<int:score>') def hello_name(score): return render_template('hello.html', marks = score) if __name__ == '__main__': app.run(debug = True) <!doctype html> <html> <body> {% if marks>50 %} <h1> Your result is pass!</h1> {% else %} <h1>Your result is fail</h1> {% endif %} </body> </html> HTML Template script
  • 33. Python Certification Training https://www.edureka.co/python Flask – Templates Another example from flask import Flask, render_template app = Flask(__name__) @app.route('/result') def result(): dict = {'phy':50,'che':60,'maths':70} return render_template('result.html', result = dict) if __name__ == '__main__': app.run(debug = True) <!doctype html> <html> <body> <table border = 1> {% for key, value in result.iteritems() %} <tr> <th> {{ key }} </th> <td> {{ value }} </td> </tr> {% endfor %} </table> </body> </html>
  • 34. Python Certification Training https://www.edureka.co/python Flask – Static Files
  • 35. Python Certification Training https://www.edureka.co/python Flask – Static Files Web application will require a static file such as JS or CSS file from flask import Flask, render_template app = Flask(__name__) @app.route('/result') def result(): dict = {'phy':50,'che':60,'maths':70} return render_template('result.html', result = dict) if __name__ == '__main__': app.run(debug = True) <!doctype html> <html> <body> <table border = 1> {% for key, value in result.iteritems() %} <tr> <th> {{ key }} </th> <td> {{ value }} </td> </tr> {% endfor %} </table> </body> </html> Python function sayHello() { alert("Hello World") } JS File HTML
  • 36. Python Certification Training https://www.edureka.co/python Flask – Request Object
  • 37. Python Certification Training https://www.edureka.co/python Flask – Request Object Data from client’s webpage is sent to server as a global request object Form Dictionary object containing key-value pairs of form parameters and values args Parsed contents of query string which is part of URL after question mark (?) Cookies Dictionary object holding Cookie names and values files Data pertaining to uploaded file Method Current request method
  • 38. Python Certification Training https://www.edureka.co/python Flask – Cookies
  • 39. Python Certification Training https://www.edureka.co/python Flask – Cookies Cookie is stored on client’s machine. And helps with data tracking @app.route('/') def index(): return render_template('index.html') <html> <body> <form action = "/setcookie" method = "POST"> <p><h3>Enter userID</h3></p> <p><input type = 'text' name = 'nm'/></p> <p><input type = 'submit' value = 'Login'/></p> </form> </body> </html> @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 @app.route('/getcookie') def getcookie(): name = request.cookies.get('userID') return '<h1>welcome '+name+'</h1>'
  • 40. Python Certification Training https://www.edureka.co/python Flask – Redirect & Errors
  • 41. Python Certification Training https://www.edureka.co/python Flask – Redirect & Errors Flask Class has a redirect() function which returns a response object Prototype Flask.redirect(location, statuscode, response) URL where response should be redirected Statuscode sent to browser’s header Response parameter used to instantiate response
  • 42. Python Certification Training https://www.edureka.co/python Flask – Redirect & Errors Standardized status codes Sl.no Status Code 1 HTTP_300_MULTIPLE_CHOICES 2 HTTP_301_MOVED_PERMANENTLY 3 HTTP_302_FOUND 4 HTTP_303_SEE_OTHER 5 HTTP_304_NOT_MODIFIED 6 HTTP_305_USE_PROXY 7 HTTP_306_RESERVED Sl.no Code Description 1 400 Bad Request 2 401 Unauthenticated 3 403 Forbidden 4 404 Not Found 5 406 Not Acceptable 6 415 Unsupported Media Type 7 429 Too Many Requests Prototype Flask.abort(code)
  • 43. Python Certification Training https://www.edureka.co/python Flask – Extensions
  • 44. Python Certification Training https://www.edureka.co/python Flask – Extensions Flask is a micro framework Large number of extensions Flask Mail Flask WTF Flask SQLAlchemy Flask Sijax Provides SMTP interface to Flask application Adds rendering & validation of WTForms Adds SQLAlchemy support to Flask Application Interface for Sijax – Python/jQuery library that makes AJAX easy to use Extensive Documentation
  • 45. Python Certification Training https://www.edureka.co/python Conclusion
  • 46. Python Certification Training https://www.edureka.co/python Conclusion