Activity #22: Research: Python Flask

What is Flask?

  • Flask is a lightweight and easy-to-use web framework for Python. It’s designed to be simple and flexible, providing the essential tools to build web applications without requiring large overhead.

  • It’s called a "micro-framework" because it doesn’t require specific libraries or tools by default, although you can add extensions as needed.

Installing Flask

  • Before you can use Flask, you’ll need to install it using pip. Open your terminal or command prompt and run:

      pip install Flask
    
  • After installation, you can verify it by checking the version:

      python -m flask --version
    

Creating Your First Flask Application

Here’s a simple step-by-step guide to creating your first Flask app:

  1. Create a New Project Folder:

    • Create a folder where you will keep your Flask project.

Example:

    mkdir flask_app
    cd flask_app
  1. Create a Python File:

    • Inside the flask_app folder, create a file named app.py.
  2. Basic Flask Application Code:

    • Open app.py and write the following code to create a basic Flask application:
    from flask import Flask

    # Create a Flask app instance
    app = Flask(__name__)

    # Define a route
    @app.route('/')
    def home():
        return "Hello, Flask!"

    # Run the application
    if __name__ == '__main__':
        app.run(debug=True)
  • Explanation:

    • Flask(__name__): Initializes the Flask application.

    • @app.route('/'): Sets up a route to handle requests to the homepage (/).

    • return "Hello, Flask!": Returns this message when visiting the homepage.

    • app.run(debug=True): Starts the web server in debug mode so you can see real-time changes.

Running the Flask Application

  • Run the Flask application by executing the following command:

      python app.py
    
  • After running the command, Flask will start a development server. You should see an output like this:

      * Running on http://127.0.0.1:5000/ (Press CTRL+C to quit)
    
  • Open your browser and go to http://127.0.0.1:5000/. You should see "Hello, Flask!" displayed on the page.

    http://127.0.0.1:5000

Routing in Flask

  • Flask allows you to define different routes (URLs) that map to specific functions in your application. Here’s how you can add more routes:

  • Update app.py

      @app.route('/about')
      def about():
          return "This is the About page."
    
      @app.route('/contact')
      def contact():
          return "Contact us at contact@example.com"
    
  • Now, visiting /about and /contact in your browser will show different messages.

    • Go to: http://127.0.0.1:5000/about → This will display: "This is the About page."

    • Go to: http://127.0.0.1:5000/contact → This will display: "Contact us at "

Dynamic Routing

  • You can also create dynamic routes that take parameters. For example, you can display a personalized greeting by capturing a username from the URL:

      @app.route('/user/<name>')
      def user(name):
          return f"Hello, {name}!"
    
  • If you visit http://127.0.0.1:5000/user/Monet, you will see "Hello, Monet!".

Rendering HTML Templates

  • Flask allows you to serve HTML files using templates. To do this, you need to create a folder called templates where your HTML files will be stored.
  1. Create a Folder for Templates:

    • Inside your project folder, create a templates folder and create an HTML file inside it. For example, create index.html:
    <!-- templates/index.html -->
    <html>
    <head>
        <title>Flask App</title>
    </head>
    <body>
        <h1>Welcome to Flask!</h1>
    </body>
    </html>
  1. Modify Your Flask Code to Render Templates:

     from flask import Flask, render_template
    
     app = Flask(__name__)
    
     @app.route('/')
     def home():
         return render_template('index.html')
    
  • Now when you visit the homepage, Flask will serve the index.html file.

Handling Forms and POST Requests

  • Flask supports handling form data and POST requests. Here’s an example where a user submits their name through a form:
  1. Create a Form in HTML (form.html):

     <!-- templates/form.html -->
     <form method="POST">
         Name: <input type="text" name="name">
         <input type="submit">
     </form>
    
  2. Update Your Flask Application to Handle the Form:

     from flask import Flask, render_template, request
    
     app = Flask(__name__)
    
     @app.route('/form', methods=['GET', 'POST'])
     def form():
         if request.method == 'POST':
             name = request.form['name']
             return f"Hello, {name}!"
         return render_template('form.html')
    
  • Now, when you visit /form, you’ll see the form. After submitting your name, it will display a personalized greeting.

  • Open your browser and go to http://127.0.0.1:5000/form.

Using Flask Extensions

  • Flask has many extensions that add more features to your app, such as authentication, database handling, etc. Some common extensions include:

    • Flask-SQLAlchemy for database management.

    • Flask-WTF for working with forms.

    • Flask-Login for user authentication.

You can install them via pip:

pip install Flask-SQLAlchemy
pip install Flask-WTF
pip install Flask-Login