Jump to content

Flask (web framework)

From Wikipedia, the free encyclopedia
(Redirected from Werkzeug)
Flask
Developer(s)Armin Ronacher
Initial release1 April 2010; 14 years ago (2010-04-01)
Stable release
3.1.0[1] Edit this on Wikidata / 13 November 2024; 36 days ago (13 November 2024)
Repositorygithub.com/pallets/flask
Written inPython
TypeWeb framework
LicenseBSD 3-clause license
Websitepalletsprojects.com/p/flask/

Flask is a micro web framework written in Python. It is classified as a microframework because it does not require particular tools or libraries.[2] It has no database abstraction layer, form validation, or any other components where pre-existing third-party libraries provide common functions. However, Flask supports extensions that can add application features as if they were implemented in Flask itself. Extensions exist for object-relational mappers, form validation, upload handling, various open authentication technologies and several common framework related tools.[3]

Applications that use the Flask framework include Pinterest and LinkedIn.[4][5]

History

[edit]

Flask was created by Armin Ronacher of Pocoo, an international group of Python enthusiasts formed in 2004.[6] According to Ronacher, the idea was originally an April Fool's joke that was popular enough to make into a serious application.[7][8][9] The name is a play on the earlier Bottle framework.[7]

When Ronacher and Georg Brandl created a bulletin board system written in Python in 2004, the Pocoo projects Werkzeug and Jinja were developed.[10]

In April 2016, the Pocoo team was disbanded and development of Flask and related libraries passed to the newly formed Pallets project.[11][12] Since 2018, Flask-related data and objects can be rendered with Bootstrap.[13]

Flask has become popular among Python enthusiasts. As of October 2020, it has the second-most number of stars on GitHub among Python web-development frameworks, only slightly behind Django,[14] and was voted the most popular web framework in the Python Developers Survey for years between and including 2018 and 2022.[15][16][17][18][19]

Components

[edit]

The microframework Flask is part of the Pallets Projects (formerly Pocoo), and based on several others of them, all under a BSD license.

Werkzeug

[edit]

Werkzeug (German for "tool") is a utility library for the Python programming language for Web Server Gateway Interface (WSGI) applications. Werkzeug can instantiate objects for request, response, and utility functions. It can be used as the basis for a custom software framework and supports Python 2.7 and 3.5 and later.[20][21]

Jinja

[edit]

Jinja, also by Ronacher, is a template engine for the Python programming language. Similar to the Django web framework, it handles templates in a sandbox.

MarkupSafe

[edit]

MarkupSafe is a string handling library for the Python programming language. The eponymous MarkupSafe type extends the Python string type and marks its contents as "safe"; combining MarkupSafe with regular strings automatically escapes the unmarked strings, while avoiding double escaping of already marked strings.

ItsDangerous

[edit]

ItsDangerous is a safe data serialization library for the Python programming language. It is used to store the session of a Flask application in a cookie without allowing users to tamper with the session contents.

Features

[edit]
  • Development server and debugger
  • Integrated support for unit testing
  • RESTful request dispatching
  • Uses Jinja templating
  • Support for secure cookies (client side sessions)
  • 100% WSGI 1.0 compliant
  • Unicode-based
  • Complete documentation
  • Google App Engine compatibility
  • Extensions available to extend functionality

Example

[edit]

The following code shows a simple web application that displays "Hello World!" when visited:

from flask import Flask
app = Flask(__name__)

@app.route("/")
def hello() -> str:
    return "Hello World"


if __name__ == "__main__":
    app.run()

See also

[edit]

References

[edit]
  1. ^ "Release 3.1.0". 13 November 2024. Retrieved 21 November 2024.
  2. ^ "Flask Foreword". Archived from the original on 2017-11-17.
  3. ^ "Flask Extensions". Archived from the original on 2018-05-17.
  4. ^ What challenges has Pinterest encountered with Flask?
  5. ^ Rachel Sanders: Developing Flask Extensions - PyCon 2014
  6. ^ "Pocoo Team". Archived from the original on 2018-03-15.
  7. ^ a b Ronacher, Armin. "Opening the Flask" (PDF). Archived from the original (PDF) on 2016-12-17. Retrieved 2011-09-30.
  8. ^ Ronacher, Armin (3 April 2010). "April 1st Post Mortem". Armin Ronacher's Thoughts and Writings. Archived from the original on 2018-05-14. Retrieved 2015-07-25.
  9. ^ "Denied: the next generation python micro-web-framework (April Fools page)". Archived from the original on 2011-09-04. Retrieved 2011-09-30.
  10. ^ "History". Pocoo Team. Archived from the original on 2017-11-19. Retrieved 2015-03-25.
  11. ^ Ronacher, Armin (2016-04-01). "Hello Pallets Users". The Pallets Projects. Retrieved 2021-05-08.
  12. ^ "Pocoo". www.pocoo.org. Retrieved 2021-05-08.
  13. ^ "Bootstrap-Flask". HelloFlask. Retrieved 2022-11-06.
  14. ^ "Python libraries by GitHub stars". Github. Retrieved 2020-01-27.
  15. ^ "Python Developers Survey 2018". www.jetbrains.com. 2018-11-01.
  16. ^ "Python Developers Survey 2019". www.jetbrains.com. 2019.
  17. ^ "Python Developers Survey 2020". www.jetbrains.com. 2020.
  18. ^ "Python Developers Survey 2021". www.jetbrains.com. 2021.
  19. ^ "Python Developers Survey 2022 Results". www.jetbrains.com. 2022. Retrieved 2023-10-17.
  20. ^ Ronacher, Armin. "Werkzeug The Python WSGI Utility Library". palletsprojects.com. Retrieved 27 May 2018.
  21. ^ Ronacher, Armin. "Installation, Python Version". palletsprojects.com. Archived from the original on 11 May 2021. Retrieved 20 April 2020.
[edit]