29.11.2024

How to write a web application in Flask?

Nowadays web is the easiest and most common way to provide services. Almost all spheres from online banking to delivery already have or plan to implement web applications in their infrastructure. There are many frameworks that combine libraries and instructions for developing such applications: Django, Flask, ASP.NET Core, Laravel, etc.

In this article, we will look at a quick way to manage and work with one of them, more specifically Flask! We will write an application that will route requests to the necessary functions, render an HTML page for output, and define some logic for processing requests.

What is a web application and how does it differ from a regular application?

Usually, a server application is a set of instructions and/or executable files, configurations, libraries that process client requests over network or file sockets.

Screenshot №1 — Schema

But a web application processes requests using protocols that work on the web, receiving a full URL as input and breaking it down into path, method, headers and packet body. With respect to the received packets with paths Flask decides which code functions should be executed. For example, a client calls the web with a request of the form:

hxxps://gg.com/about

Flask has the following application structure:from flask import Flask, render_template:

app = Flask(__name__)
@app.route('/about')
def index():
return render_template('index.html')

Upon receiving the packet, Flask web framework starts looking for a path that matches the client's request and method. In this case, it immediately routes the request to @app.route('/about'), where the my function will be executed:

def my():
return render_template('my.html')

Accordingly, the client will receive an HTML page in response, which will be returned by the application server or the web server.

How to quickly write an application in Flask Python?

Creating a web application from a regular one is almost no different at the initial stages, it is the same directory containing a set of instructions, libraries and static and dynamic content.

Let's create a project folder and installing flask with all the necessary dependencies:

mkdir –p ~/web_app/ && cd ~/web_app && apt install python3 python-pip3 flask python3-venv -y

Screenshot №2 — Installation

In the another way to installation flask python we can use pip:

pip install flask

After that, to delimit environment variables, we will create a virtual environment using venv:

python3 –m venv ~/web_app/venv

Screenshot №3 — Venv

This solution will allow you to create your own file of environment variables and dependencies for a given project, all that remains is to replace your current file with the created one:

source ~/web_app/venv/bin/activate

Let's commit the used software package to be sent for deployment so that we don't have dependency problems:

pip freeze > ~/web_app/requirements.txt

Screenshot №4 — PIP freeze

Now let's create the necessary application:

nano ~/web_app/app.py

Let's spell out the basic instructions for running the application:

from flask import Flask
from flask import Flask

app = Flask(__name__)

@app.route('/about')
def about_func():
return 'Wake up! Patrick!'

if __name__ == '__main__':
app.run(debug=True)

Screenshot №5 — Application for usage

Let's explain each of the existing lines:

As a result, the resulting code should be saved and run on the interpreter:

python3 ./app.py

Screenshot №6 — Start application

Ultimately, the structure of the project may be as follows:

/your-app
/static
/dynamic
app.py
/venv

After that, you need to navigate to one of the addresses that have been defined:

Screenshot №7 — Check application

Great, a basic application that can output text is ready! But what if we need to output HTML pages that have been pre-prepared or JSON files?

To do this, let's add a couple libraries and lines of code to the existing configuration:

from flask import Flask, render_template
app = Flask(__name__)
@app.route('/')
def main_page():
return render_template('main.html')
@app.route('/id/<username>')
def to_dict(username):
data = {
'username': {username},
}
if __name__ == '__main__':
app.run(debug=True)

Now, respectively, when calling paths in URL /id/<username> and / we will get the results of related functions.To work with methods other than GET, it is necessary to explicitly specify them when setting up routes to functions from flask import request import os:

@app.route('/click', methods=['DELETE'])
def click():
name = request.form['value']
os.remove(f"/home/{name}")
return 'Complete task!'

Then by calling the DELETE method with the passed form of invocation, we will be able to delete files from the /home folder. The framework has many more different ways of working and implementing the logic, which you can check out in our pool of instructions on python and flask! 
If you don't have sufficient resources than you can perform actions on powerful cloud servers. Serverspace provides isolated VPS / VDS servers for common and virtualize usage also can fit for python web framework flask!

Screenshot №8 — Create Server