Routing dan Metode HTTP dalam Flask

From OnnoWiki
Jump to navigation Jump to search

Dalam pengembangan aplikasi web menggunakan Python, Flask menyediakan mekanisme routing yang memungkinkan pengembang untuk menentukan bagaimana aplikasi merespons berbagai permintaan URL dan metode HTTP. Routing adalah proses pemetaan URL ke fungsi tertentu dalam aplikasi, sementara metode HTTP seperti GET, POST, PUT, dan DELETE menentukan jenis operasi yang dilakukan pada sumber daya. Modul ini akan membahas cara kerja routing di Flask, berbagai metode HTTP, serta memberikan contoh implementasi endpoint dengan metode-metode tersebut.

Instalasi Flask di Ubuntu 24.04

Sebelum memulai, pastikan Anda telah menginstal Flask pada sistem Ubuntu 24.04 Anda. Berikut adalah langkah-langkah instalasinya:

1. Perbarui daftar paket dan instal dependensi:

sudo apt update
sudo apt install python3 python3-pip -y
  

2. Buat direktori proyek dan navigasikan ke dalamnya:

mkdir flask_project
cd flask_project
 

3. Buat dan aktifkan virtual environment:

python3 -m venv venv
source venv/bin/activate

4. Instal Flask:

pip install Flask

Memahami Routing dalam Flask

Routing dalam Flask dilakukan dengan mendekorasi fungsi Python menggunakan `@app.route`. Dekorator ini menghubungkan URL tertentu dengan fungsi yang akan dipanggil saat URL tersebut diakses. Secara default, Flask hanya merespons metode GET kecuali ditentukan lain.

Contoh:

from flask import Flask

app = Flask(__name__)

@app.route('/')
def home():
    return 'Selamat datang di halaman utama!'

@app.route('/about')
def about():
    return 'Ini adalah halaman tentang kami.'

Dalam contoh di atas, dua rute didefinisikan: `/` untuk halaman utama dan `/about` untuk halaman "tentang kami". Setiap kali URL tersebut diakses, fungsi terkait akan dipanggil dan mengembalikan respons yang sesuai.

Metode HTTP dalam Flask

Flask mendukung berbagai metode HTTP yang memungkinkan aplikasi untuk menangani berbagai jenis permintaan. Metode-metode tersebut meliputi:

  • GET: Mengambil data dari server.
  • POST: Mengirim data ke server untuk membuat atau memperbarui sumber daya.
  • PUT: Memperbarui seluruh sumber daya di server.
  • DELETE: Menghapus sumber daya dari server.

Untuk menangani metode-metode ini, parameter `methods` digunakan dalam dekorator `@app.route`.

Contoh:

from flask import Flask, request

app = Flask(__name__)

@app.route('/user', methods=['GET', 'POST', 'PUT', 'DELETE'])
def user():
    if request.method == 'GET':
        return 'Mengambil data pengguna.'
    elif request.method == 'POST':
        return 'Menambahkan data pengguna.'
    elif request.method == 'PUT':
        return 'Memperbarui data pengguna.'
    elif request.method == 'DELETE':
        return 'Menghapus data pengguna.'

Dalam contoh ini, fungsi `user` dapat menangani keempat metode HTTP tersebut, dan memberikan respons yang berbeda berdasarkan metode yang digunakan dalam permintaan.

Membuat Endpoint dengan Berbagai Metode HTTP

Berikut adalah contoh implementasi endpoint yang menangani operasi CRUD (Create, Read, Update, Delete) untuk entitas "artikel" menggunakan berbagai metode HTTP:

from flask import Flask, request, jsonify

app = Flask(__name__)

# Data sementara sebagai pengganti basis data
articles = []

@app.route('/articles', methods=['GET', 'POST'])
def manage_articles():
    if request.method == 'GET':
        return jsonify(articles)
    elif request.method == 'POST':
        new_article = request.get_json()
        articles.append(new_article)
        return jsonify(new_article), 201

@app.route('/articles/<int:article_id>', methods=['GET', 'PUT', 'DELETE'])
def handle_article(article_id):
    if article_id >= len(articles) or article_id < 0:
        return 'Artikel tidak ditemukan', 404

    if request.method == 'GET':
        return jsonify(articles[article_id])
    elif request.method == 'PUT':
        updated_article = request.get_json()
        articles[article_id] = updated_article
        return jsonify(updated_article)
    elif request.method == 'DELETE':
        articles.pop(article_id)
        return , 204

Penjelasan:

  • GET /articles: Mengambil daftar semua artikel.
  • POST /articles: Menambahkan artikel baru ke daftar.
  • GET /articles/<article_id>: Mengambil detail artikel berdasarkan ID.
  • PUT /articles/<article_id>: Memperbarui artikel berdasarkan ID.
  • DELETE /articles/<article_id>: Menghapus artikel berdasarkan ID.

Dalam implementasi ini, data disimpan dalam daftar Python sederhana sebagai pengganti basis data untuk keperluan demonstrasi. Dalam aplikasi nyata, Anda disarankan untuk menggunakan basis data yang sesuai.

Kesimpulan

Flask menyediakan mekanisme routing yang fleksibel dan mendukung berbagai metode HTTP, memungkinkan pengembang untuk membangun aplikasi web yang responsif dan efisien. Dengan memahami cara kerja routing dan metode HTTP, serta implementasi endpoint untuk operasi CRUD, Anda dapat mengembangkan aplikasi web yang sesuai dengan kebutuhan pengguna.

Referensi

Pranala Menarik