Rumah pembangunan bahagian belakang Tutorial Python Flask-RESTful dan Swagger: Amalan terbaik untuk membina API RESTful dalam aplikasi web Python (Bahagian 2)

Flask-RESTful dan Swagger: Amalan terbaik untuk membina API RESTful dalam aplikasi web Python (Bahagian 2)

Jun 17, 2023 am 10:39 AM
restful flask swagger

Flask-RESTful dan Swagger: Amalan terbaik untuk membina API RESTful dalam aplikasi web Python (Bahagian 2)

Dalam artikel sebelumnya, kami meneroka cara menggunakan Flask-RESTful dan Swagger kepada amalan Terbaik untuk membina RESTful API. Kami memperkenalkan asas rangka kerja Flask-RESTful dan menunjukkan cara menggunakan Swagger untuk membina dokumentasi untuk API RESTful. Artikel ini terus menyelidiki topik ini dan memperkenalkan teknik dan amalan yang lebih maju.

  1. Gunakan Keizinan dan Pengesahan

RESTful API harus selamat, memastikan hanya pengguna yang diberi kuasa boleh mengaksesnya. Untuk mencapai ini kita perlu menggunakan Kebenaran dan Pengesahan. Keizinan ialah proses menentukan sama ada pengguna dibenarkan mengakses sumber. Pengesahan ialah proses mengesahkan identiti pengguna.

Flask-RESTful menyediakan sambungan yang sangat berguna, Flask-JWT. Flask-JWT boleh membantu kami melaksanakan pengurusan pengesahan dan kebenaran berasaskan token. Di sini kami memperkenalkan secara ringkas cara menggunakan Flask-JWT untuk melaksanakan pengesahan token.

from flask import Flask
from flask_jwt import JWT, jwt_required, current_identity
from werkzeug.security import safe_str_cmp

app = Flask(__name__)
app.config['SECRET_KEY'] = 'super-secret'

class User:
   def __init__(self, id, username, password):
      self.id = id
      self.username = username
      self.password = password

   def __str__(self):
      return "User(id='%s')" % self.id

users = [
   User(1, 'john', 'pass'),
   User(2, 'susan', 'pass'),
]

username_table = {u.username: u for u in users}
userid_table = {u.id: u for u in users}

def authenticate(username, password):
   user = username_table.get(username, None)
   if user and safe_str_cmp(user.password.encode('utf-8'), password.encode('utf-8')):
      return user

def identity(payload):
   user_id = payload['identity']
   return userid_table.get(user_id, None)

jwt = JWT(app, authenticate, identity)

@app.route('/protected')
@jwt_required()
def protected():
   return '%s' % current_identity

if __name__ == '__main__':
   app.run()
Salin selepas log masuk

Dalam kod di atas, kami mencipta objek JWT yang disambungkan ke aplikasi Flask. Objek JWT menggunakan SECRET_KEY apl Flask untuk menyulitkan dan menyahsulit token. Kami juga mentakrifkan kelas pengguna, dan maklumat pengguna disimpan dalam senarai pengguna.

Apabila mentakrifkan fungsi pengesahan authenitcate, kami menyemak sama ada nama pengguna wujud dan membawa maklumat kata laluan. Jika pengesahan kata laluan lulus, fungsi mengembalikan objek pengguna. Apabila mentakrifkan identiti fungsi identiti, kami mengembalikan objek pengguna yang disahkan.

Di bawah penghias @app.route('/protected'), penghias @jwt_required() digunakan untuk melindungi titik akhir ini, memastikan hanya pengguna yang disahkan dan dibenarkan sahaja boleh mengaksesnya.

  1. Melaksanakan kawalan versi

Kawalan versi ialah konsep yang sangat penting kerana ia menjadikan interaksi antara klien dan pelayan stabil dan serasi ke belakang. API harus mengekalkan keserasian antara pelanggan dan pelayan sebanyak mungkin, terutamanya apabila terdapat perubahan besar pada API. Untuk mencapai kawalan versi, kami perlu memperkenalkan nombor versi dalam API.

Berikut ialah amalan versi yang baik:

from flask import Flask
from flask_restful import Resource, Api

app = Flask(__name__)
api = Api(app)
version = 'v1'

class HelloWorld(Resource):
    def get(self):
        return {'version': version, 'message': 'Hello World'}

api.add_resource(HelloWorld, f'/{version}/')

if __name__ == '__main__':
   app.run()
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan pembolehubah versi untuk menentukan versi API dan kemudian menggunakannya dalam @app.route decorator f -{version}-String untuk menambah nombor versi. Ini membolehkan kawalan versi dan keserasian antara muka yang lebih baik antara klien dan pelayan.

  1. Menggunakan sambungan lain

Flask-RESTful menyediakan banyak pemalam kebolehlanjutan yang boleh membantu anda membina API RESTful dengan lebih pantas dan lebih mudah. Berikut ialah beberapa sambungan yang biasa digunakan:

  • Flask-CORS: Selesaikan masalah akses merentas domain aplikasi.
  • Flask-Bcrypt: Menyediakan fungsi pencincangan kata laluan bcrypt untuk menyulitkan kata laluan.
  • Flask-Migrate: Menyediakan pemindahan data dan fungsi peningkatan pangkalan data.
  • Flask-Login: Menyediakan fungsi log masuk pengguna.

Pelanjutan ini membantu anda membina API RESTful dengan lebih cekap.

Ringkasan

Artikel ini menyelami amalan terbaik cara menggunakan Flask-RESTful dan Swagger untuk membina API RESTful. Kami memperkenalkan cara menggunakan Kebenaran dan Pengesahan untuk memastikan keselamatan API dan cara melaksanakan kawalan versi. Pada masa yang sama, untuk membina API dengan lebih baik, kami juga memperkenalkan beberapa sambungan Flask yang biasa digunakan. Amalan ini akan membantu anda membina API RESTful dengan lebih cepat dan menjadikan interaksi antara klien dan pelayan lebih stabil dan serasi ke belakang.

Atas ialah kandungan terperinci Flask-RESTful dan Swagger: Amalan terbaik untuk membina API RESTful dalam aplikasi web Python (Bahagian 2). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Cara membina aplikasi web yang ringkas dan mudah digunakan dengan React dan Flask Cara membina aplikasi web yang ringkas dan mudah digunakan dengan React dan Flask Sep 27, 2023 am 11:09 AM

Cara menggunakan React dan Flask untuk membina aplikasi web yang ringkas dan mudah digunakan Pengenalan: Dengan perkembangan Internet, keperluan aplikasi web menjadi semakin pelbagai dan kompleks. Untuk memenuhi keperluan pengguna untuk kemudahan penggunaan dan prestasi, semakin penting untuk menggunakan tindanan teknologi moden untuk membina aplikasi rangkaian. React dan Flask ialah dua rangka kerja yang sangat popular untuk pembangunan bahagian hadapan dan belakang, dan ia berfungsi dengan baik bersama-sama untuk membina aplikasi web yang ringkas dan mudah digunakan. Artikel ini akan memperincikan cara memanfaatkan React dan Flask

Django vs. Flask: Analisis perbandingan rangka kerja web Python Django vs. Flask: Analisis perbandingan rangka kerja web Python Jan 19, 2024 am 08:36 AM

Django dan Flask adalah kedua-duanya peneraju dalam rangka kerja Web Python, dan kedua-duanya mempunyai kelebihan dan senario yang boleh digunakan. Artikel ini akan menjalankan analisis perbandingan kedua-dua rangka kerja ini dan memberikan contoh kod khusus. Pengenalan Pembangunan Django ialah rangka kerja Web berciri penuh, tujuan utamanya adalah untuk membangunkan aplikasi Web yang kompleks dengan cepat. Django menyediakan banyak fungsi terbina dalam, seperti ORM (Pemetaan Hubungan Objek), borang, pengesahan, bahagian belakang pengurusan, dsb. Ciri-ciri ini membolehkan Django mengendalikan besar

Mulakan dari awal dan bimbing anda langkah demi langkah untuk memasang Flask dan segera buat blog peribadi Mulakan dari awal dan bimbing anda langkah demi langkah untuk memasang Flask dan segera buat blog peribadi Feb 19, 2024 pm 04:01 PM

Bermula dari awal, saya akan mengajar anda langkah demi langkah cara memasang Flask dan cepat membina blog peribadi Sebagai seorang yang suka menulis, mempunyai blog peribadi adalah sangat penting. Sebagai rangka kerja Web Python yang ringan, Flask boleh membantu kami membina blog peribadi yang ringkas dan berfungsi sepenuhnya dengan cepat. Dalam artikel ini, saya akan bermula dari awal dan mengajar anda langkah demi langkah cara memasang Flask dan membina blog peribadi dengan cepat. Langkah 1: Pasang Python dan pip Sebelum bermula, kita perlu memasang Python dan pi terlebih dahulu

Panduan untuk memasang rangka kerja Flask: Langkah terperinci untuk membantu anda memasang Flask dengan betul Panduan untuk memasang rangka kerja Flask: Langkah terperinci untuk membantu anda memasang Flask dengan betul Feb 18, 2024 pm 10:51 PM

Tutorial pemasangan rangka kerja Flask: Ajar anda langkah demi langkah cara memasang rangka kerja Flask dengan betul. Contoh kod khusus diperlukan. Ia mudah dipelajari, mudah digunakan dan padat dengan ciri yang hebat. Artikel ini akan membawa anda langkah demi langkah untuk memasang rangka kerja Flask dengan betul dan memberikan contoh kod terperinci untuk rujukan. Langkah 1: Pasang Python Sebelum memasang rangka kerja Flask, anda perlu terlebih dahulu memastikan bahawa Python dipasang pada komputer anda. Anda boleh bermula dari P

Flask vs FastAPI: Pilihan terbaik untuk pembangunan API Web yang cekap Flask vs FastAPI: Pilihan terbaik untuk pembangunan API Web yang cekap Sep 27, 2023 pm 09:01 PM

FlaskvsFastAPI: Pilihan terbaik untuk pembangunan WebAPI yang cekap Pengenalan: Dalam pembangunan perisian moden, WebAPI telah menjadi bahagian yang sangat diperlukan. Mereka menyediakan data dan perkhidmatan yang membolehkan komunikasi dan saling kendali antara aplikasi yang berbeza. Apabila memilih rangka kerja untuk membangunkan WebAPI, Flask dan FastAPI ialah dua pilihan yang telah menarik banyak perhatian. Kedua-dua rangka kerja sangat popular dan masing-masing mempunyai kelebihan tersendiri. Dalam artikel ini, kita akan melihat Fl

Membandingkan prestasi Gunicorn dan uWSGI untuk penggunaan aplikasi Flask Membandingkan prestasi Gunicorn dan uWSGI untuk penggunaan aplikasi Flask Jan 17, 2024 am 08:52 AM

Penggunaan aplikasi flask: Perbandingan Gunicorn vs suWSGI Pengenalan: Flask, sebagai rangka kerja Web Python yang ringan, disukai oleh banyak pembangun. Apabila menggunakan aplikasi Flask ke persekitaran pengeluaran, memilih Antara Muka Gerbang Pelayan (SGI) yang sesuai adalah keputusan penting. Gunicorn dan uWSGI ialah dua pelayan SGI biasa Artikel ini akan menerangkannya secara terperinci.

Tutorial pemasangan dan konfigurasi kelalang: alat untuk membina aplikasi web Python dengan mudah Tutorial pemasangan dan konfigurasi kelalang: alat untuk membina aplikasi web Python dengan mudah Feb 20, 2024 pm 11:12 PM

Tutorial pemasangan dan konfigurasi kelalang: Alat untuk membina aplikasi Web Python dengan mudah, contoh kod khusus diperlukan Pengenalan: Dengan peningkatan populariti Python, pembangunan Web telah menjadi salah satu kemahiran yang diperlukan untuk pengaturcara Python. Untuk menjalankan pembangunan web dalam Python, kita perlu memilih rangka kerja web yang sesuai. Di antara banyak rangka kerja Web Python, Flask ialah rangka kerja yang ringkas, mudah digunakan dan fleksibel yang digemari oleh pembangun. Artikel ini akan memperkenalkan pemasangan rangka kerja Flask,

Menyelam mendalam ke dalam enjin templat Django dan Jinja2 Flask Menyelam mendalam ke dalam enjin templat Django dan Jinja2 Flask Sep 28, 2023 am 11:39 AM

Untuk pemahaman yang mendalam tentang enjin templat Django dan Jinja2 Flask, contoh kod khusus diperlukan Pengenalan: Django dan Flask ialah dua rangka kerja web yang biasa digunakan dan popular dalam Python. Kedua-duanya menyediakan enjin templat yang berkuasa untuk mengendalikan pemaparan halaman web dinamik. Django menggunakan enjin templatnya sendiri, manakala Flask menggunakan Jinja2. Artikel ini akan melihat secara mendalam pada enjin templat Django dan Jinja2 Flask, dan memberikan beberapa contoh kod konkrit untuk menggambarkan penggunaannya.

See all articles