You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

3.7 KiB

Flask logo

###What to use Flask for and when to use it. Flask is an all-purpose microframework for Python based on Werkzeug and Jinja2. It is ideally suited for Python developers looking for an easily extensible framework to quickly create smaller apps. However, with some effort it can also accomodate the requirements of larger projects. Flask has great unofficial and official documentation and an active development community.

######Unique aspects

Flask has several unique aspects which sets it apart from more tightly integrated frameworks.

For instance, Flask does not force developers to use particular tools or libraries, nor does it have built-in components where third-party libraries provide common functions. Instead, Flask is easily extensible to add extra functionality. If a desired extension doesn't exist, developers can write a stand-alone library and bridge that library to Flask by wrapping it in an extension.

Unlike other frameworks which include an ORM, Flask developers can choose how they want their data to be stored. Flask applications can use existing Python libaries for projects that aren't suited to work with a standard ORM. This makes Flask easier to use with non-relational databases than more tightly integrated frameworks.

Unlike frameworks which use the module approach, Flask utilizes application dispatching which isolates the same or different Flask applications from each other in the same Python interpreter process. This is useful for developers who want to use multiple instances of the same application with different configurations, OR ?


###FAQs: #####Is it ready?

It's still not 1.0 but it's shaping up nicely and is already widely used. We believe that the project doesn't have to fundamentally change to remain relevant. Therefore, the future of Flask is that it becomes more stable and sees minimal changes beyond the required new releases and updates. Slight improvements will also be made to the API over time but there aren't plans to break it.

#####What do I need to get started?

All dependencies are installed by using pip install Flask. We encourage you to use Virtualenv. Check the docs for complete installation and usage instructions. Also read the Quickstart Guide

#####Where are the docs?

Go to http://flask.pocoo.org/docs/ for a prebuilt version of the current documentation. Otherwise build them yourself from the sphinx sources in the docs folder.

#####Where are the tests?

Good that you're asking. The tests are in the tests/ folder. To run the tests use the py.test testing tool: $ py.test

#####Where can I get help?

#####What’s in the Box?

  • Built in development server and debugger
  • Integrated unit testing support
  • RESTful request dispatching
  • Uses Jinja2 templating
  • Security:
    • Session based authentication
    • Role management
    • Password encryption
    • Basic HTTP authentication
    • Token based authentication
    • Token based account activation (optional)
    • Token based password recovery / resetting (optional)
    • User registration (optional)
    • Login tracking (optional)
    • JSON/Ajax Support
    • Support for secure cookies (client side sessions)
  • 100% WSGI 1.0 compliant
  • Unicode based
  • Extensively documented