flask

Flask-RESTful

افزونه‌ای قدرتمند برای ساخت APIهای RESTful با Flask

Flask-RESTful: افزونه‌ای قدرتمند برای ساخت APIهای RESTful با Flask

Flask-RESTful یک افزونه بسیار محبوب برای فریمورک Flask است که به شما امکان می‌دهد به سرعت و به سادگی APIهای RESTful را توسعه دهید. این افزونه با ارائه ابزارها و ساختارهای از پیش تعریف شده، بسیاری از کارهای تکراری در ساخت APIها را خودکار می‌کند و به شما اجازه می‌دهد روی منطق اصلی برنامه خود تمرکز کنید.

چرا از Flask-RESTful استفاده کنیم؟

  • سادگی و سرعت توسعه: Flask-RESTful با ارائه دکوراتورها و کلاس‌های از پیش تعریف شده، فرآیند ساخت APIها را بسیار ساده و سریع می‌کند.
  • سازگاری کامل با Flask: به طور کامل با Flask یکپارچه می‌شود و از تمام قابلیت‌های آن بهره می‌برد.
  • پشتیبانی کامل از اصول REST: تمام اصول معماری REST را به خوبی پشتیبانی می‌کند و به شما کمک می‌کند APIهای استاندارد و قابل کشف بسازید.
  • سفارشی‌سازی بالا: امکان سفارشی‌سازی گسترده برای پاسخگویی به نیازهای مختلف را فراهم می‌کند.
  • مدیریت خطاهای داخلی: ابزارهای داخلی برای مدیریت خطاها و ارسال پاسخ‌های مناسب در صورت بروز خطا.
  • پشتیبانی از فرمت‌های مختلف داده: به طور پیش فرض از JSON پشتیبانی می‌کند و امکان پشتیبانی از فرمت‌های دیگر مانند XML را نیز فراهم می‌کند.
  • جامعه بزرگ و فعال: یک جامعه بزرگ و فعال وجود دارد که به شما کمک می‌کند تا سوالات خود را پاسخ دهید و مشکلات خود را حل کنید.

مفاهیم کلیدی در Flask-RESTful

  • Resource: هر منبع در API (مانند کاربران، محصولات، …) به عنوان یک کلاس Resource تعریف می‌شود.
  • Method: هر متد HTTP (GET, POST, PUT, DELETE) به عنوان یک متد در کلاس Resource تعریف می‌شود.
  • Request: درخواست‌های HTTP توسط شیء Request در Flask-RESTful مدیریت می‌شود.
  • Response: پاسخ‌های HTTP به صورت شیء Response ارسال می‌شوند.
  • Field: برای تعریف ساختار داده‌های ورودی و خروجی استفاده می‌شود.
  • Marshalling: فرآیند تبدیل داده‌های پایتون به فرمت JSON یا XML.

مثالی ساده از یک API با Flask-RESTful

from flask import Flask
from flask_restful import Resource, Api, reqparse

app = Flask(__name__)
api = Api(app)

parser = reqparse.RequestParser()
parser.add_argument('task', type=str)

class Todo(Resource):
    def get(self):
        return {'tasks': ['task1', 'task2']}

    def post(self):
        args = parser.parse_args()
        task = args['task']
        # ذخیره task در پایگاه داده
        return {'task': task}, ۲۰۱

api.add_resource(Todo, '/todos')

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

در این مثال:

  • یک Resource به نام Todo تعریف شده است.
  • متد get برای دریافت لیست وظایف و متد post برای اضافه کردن یک وظیفه جدید استفاده می‌شود.
  • از reqparse برای تجزیه پارامترهای درخواست استفاده می‌شود.

مزایای استفاده از Flask-RESTful در مقایسه با نوشتن API از ابتدا:

  • کاهش زمان توسعه: با استفاده از Flask-RESTful، می‌توانید به سرعت APIهای خود را توسعه دهید.
  • کد تمیزتر و خواناتر: ساختار منظم Flask-RESTful به شما کمک می‌کند تا کدهای تمیزتر و خواناتر بنویسید.
  • امنیت بیشتر: Flask-RESTful به طور خودکار از بسیاری از حملات رایج محافظت می‌کند.
  • جامعه بزرگ: یک جامعه بزرگ و فعال وجود دارد که به شما کمک می‌کند تا سوالات خود را پاسخ دهید و مشکلات خود را حل کنید.

چه زمانی از Flask-RESTful استفاده کنیم؟

Flask-RESTful یک افزونه قدرتمند برای فریمورک Flask است که توسعه APIهای RESTful را بسیار ساده‌تر می‌کند. این ابزار با ارائه ساختارها و ابزارهای از پیش تعریف شده، بسیاری از کارهای تکراری در ساخت APIها را خودکار کرده و به شما اجازه می‌دهد روی منطق اصلی برنامه خود تمرکز کنید.

در چه مواردی بهتر است از Flask-RESTful استفاده کنیم؟

  • وقتی به یک API RESTful سریع و کارآمد نیاز دارید: Flask-RESTful با ارائه ابزارهای قدرتمند، به شما کمک می‌کند تا APIهای خود را به سرعت و با کمترین کد توسعه دهید.
  • وقتی می‌خواهید از اصول معماری REST پیروی کنید: Flask-RESTful به طور کامل از اصول معماری REST پشتیبانی می‌کند و به شما کمک می‌کند APIهای استاندارد و قابل کشف بسازید.
  • وقتی به یک فریمورک سبک و انعطاف‌پذیر برای توسعه بک‌اند نیاز دارید: Flask-RESTful به عنوان یک افزونه برای Flask، از تمام مزایای سبک بودن و انعطاف‌پذیری Flask بهره می‌برد.
  • وقتی می‌خواهید از یک جامعه بزرگ و فعال پشتیبانی شوید: Flask-RESTful یک جامعه بزرگ و فعال دارد که به شما کمک می‌کند تا سوالات خود را پاسخ دهید و مشکلات خود را حل کنید.
  • وقتی می‌خواهید APIهایی ایجاد کنید که به راحتی با سایر سیستم‌ها و برنامه‌ها قابل یکپارچه‌سازی باشند: APIهای RESTful به دلیل استاندارد بودن و سادگی، به راحتی با سایر سیستم‌ها و برنامه‌ها قابل یکپارچه‌سازی هستند.
  • وقتی می‌خواهید از یک ابزار قدرتمند برای مدیریت داده‌های ورودی و خروجی استفاده کنید: Flask-RESTful ابزارهای قدرتمندی برای اعتبارسنجی داده‌های ورودی و تبدیل داده‌ها به فرمت‌های مختلف (مانند JSON) ارائه می‌دهد.

به طور خلاصه، اگر شما به دنبال یک ابزار ساده، قدرتمند و انعطاف‌پذیر برای توسعه APIهای RESTful با پایتون هستید، Flask-RESTful گزینه بسیار مناسبی برای شما خواهد بود.

چه زمانی ممکن است Flask-RESTful انتخاب مناسبی نباشد؟

  • وقتی به یک فریمورک کامل و پیچیده برای توسعه وب اپلیکیشن نیاز دارید: اگر شما به دنبال یک فریمورک کامل برای توسعه وب اپلیکیشن هستید که شامل قالب‌ها، فرم‌ها و سایر ویژگی‌های آماده باشد، Flask-RESTful ممکن است انتخاب مناسبی نباشد. در این موارد، فریمورک‌هایی مانند Django ممکن است گزینه بهتری باشند.
  • وقتی به عملکرد بسیار بالایی نیاز دارید و بهینه سازی هر میلی‌ثانیه برای شما بسیار مهم است: در برخی موارد، ممکن است نیاز به عملکرد بسیار بالایی داشته باشید و بهینه سازی هر میلی‌ثانیه برای شما بسیار مهم باشد. در این موارد، ممکن است لازم باشد از فریمورک‌های دیگری استفاده کنید که بهینه سازی بیشتری برای عملکرد ارائه می‌دهند.

 

اعتبارسنجی داده‌ها در Flask-RESTful

Flask-RESTful ارائه می‌دهد reqparse ماژول که به شما امکان می‌دهد پارامترهای درخواست را تجزیه و اعتبارسنجی کنید. این ماژول بسیار مفید است برای اطمینان از اینکه داده‌های ورودی به API شما معتبر و امن هستند.

نحوه استفاده از reqparse

  1. ایجاد یک شیء RequestParser:

    Python
    from flask_restful import reqparse
    
    parser = reqparse.RequestParser()
    
  2. افزودن آرگومان‌ها:

    Python
    parser.add_argument('name', type=str, required=True, help='Name cannot be blank!')
    parser.add_argument('age', type=int, required=True, help='Age cannot be blank!')
    
  3. تجزیه آرگومان‌ها:

    Python
    args = parser.parse_args()
    name = args['name']
    age = args['age']
    

انواع داده‌های پشتیبانی شده

reqparse از انواع داده مختلفی پشتیبانی می‌کند، از جمله:

  • str: رشته
  • int: عدد صحیح
  • float: عدد اعشاری
  • bool: مقدار بولی (True یا False)
  • list: لیست
  • dict: دیکشنری
  • datetime: تاریخ و زمان

اعتبارسنجی داده‌ها

می‌توانید از آرگومان required برای مشخص کردن اینکه آیا یک آرگومان اجباری است یا خیر. همچنین می‌توانید از آرگومان help برای تعیین پیام خطای سفاردی استفاده کنید.

مثال کامل

Python
from flask import Flask
from flask_restful import Resource, Api, reqparse

app = Flask(__name__)
api = Api(app)

parser = reqparse.RequestParser()
parser.add_argument('name', type=str, required=True, help='Name cannot be blank!')
parser.add_argument('age', type=int, required=True, help='Age cannot be blank!')

class User(Resource):
    def post(self):
        args = parser.parse_args()
        name = args['name']
        age = args['age']
        # ... ذخیره کاربر در پایگاه داده ...
        return {'message': 'User created successfully'}, ۲۰۱

api.add_resource(User, '/user')

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

نکات مهم:

  • مدیریت خطاها: در صورت بروز خطا در اعتبارسنجی، parse_args() یک ParseError را پرتاب می‌کند. می‌توانید این خطا را مدیریت کنید و یک پاسخ مناسب به کاربر ارسال کنید.
  • استفاده از فیلترها: برای اعتبارسنجی پیچیده‌تر، می‌توانید از فیلترهای سفارشی استفاده کنید.
  • امنیت: همیشه به خاطر داشته باشید که داده‌های ورودی از سمت کاربر می‌تواند مخرب باشد. از تکنیک‌های امنیتی مناسب مانند فیلتر کردن ورودی و جلوگیری از تزریق SQL استفاده کنید.

با استفاده از reqparse، می‌توانید به راحتی داده‌های ورودی به API خود را اعتبارسنجی کنید و از خطاهای ناشی از داده‌های نامعتبر جلوگیری کنید.

مدیریت خطاها در Flask-RESTful

Flask-RESTful ابزارها و مکانیزم‌های مختلفی را برای مدیریت خطاها در APIهای RESTful فراهم می‌کند. این ابزارها به شما کمک می‌کنند تا پاسخ‌های مناسبی را به درخواست‌های کلاینت که با خطا مواجه می‌شوند، ارسال کنید و همچنین به شما در تشخیص و رفع مشکلات در برنامه کمک می‌کنند.

روش‌های مدیریت خطا در Flask-RESTful:

  1. استفاده از استثناهای سفارشی:

    • می‌توانید استثناهای سفارشی خود را تعریف کنید تا انواع مختلف خطاها را مشخص کنید.
    • مثلاً:
      Python
      class NotFoundError(Exception):
          pass
    • سپس در کد خود از این استثناها برای نشان دادن خطاهای خاص استفاده کنید.
  2. بازگرداندن کدهای وضعیت HTTP مناسب:

    • Flask-RESTful به شما اجازه می‌دهد تا کدهای وضعیت HTTP مختلفی را برای نشان دادن وضعیت درخواست برگردانید.
    • مثلاً:
      • ۴۰۴ Not Found: زمانی که منبع مورد نظر پیدا نشود.
      • ۴۰۰ Bad Request: زمانی که درخواست نامعتبر باشد.
      • ۵۰۰ Internal Server Error: زمانی که خطای داخلی در سرور رخ دهد.
  3. استفاده از abort():

    • تابع abort() در Flask-RESTful برای قطع اجرای درخواست و بازگرداندن یک پاسخ با کد وضعیت مشخص استفاده می‌شود.
    • مثلاً:
      Python
      from flask_restful import abort
      
      abort(۴۰۴, message='User not found')
      
  4. استفاده از HTTPException:

    • کلاس HTTPException یک کلاس پایه برای استثناهای HTTP است و به شما اجازه می‌دهد استثناهای سفارشی با کد وضعیت HTTP دلخواه ایجاد کنید.

مثال:

Python
from flask import Flask, request
from flask_restful import Resource, Api, abort, reqparse

app = Flask(__name__)
api = Api(app)

parser = reqparse.RequestParser()
parser.add_argument('task', type=str, required=True, help='Task cannot be blank!')

class Todo(Resource):
    def get(self, todo_id):
        # ... کد برای دریافت کار از پایگاه داده
        if todo is None:
            abort(۴۰۴, message="Todo {} doesn't exist".format(todo_id))
        return todo

    def post(self):
        args = parser.parse_args()
        task = args['task']
        # ... کد برای ذخیره کار در پایگاه داده
        if not task:
            abort(۴۰۰, message="Task is required!")
        return {'task': task}, ۲۰۱

api.add_resource(Todo, '/todos/<todo_id>')

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

در مثال بالا:

  • اگر کاربری وجود نداشته باشد، abort(404) فراخوانی می‌شود تا یک پاسخ ۴۰۴ Not Found برگردانده شود.
  • اگر پارامتر task در درخواست POST خالی باشد، abort(400) فراخوانی می‌شود تا یک پاسخ ۴۰۰ Bad Request برگردانده شود.

نکات مهم در مدیریت خطا:

  • پیام‌های خطای واضح: پیام‌های خطا باید برای کاربران قابل فهم باشند و اطلاعات کافی برای رفع مشکل ارائه دهند.
  • کدهای وضعیت HTTP مناسب: استفاده از کدهای وضعیت HTTP مناسب به کلاینت‌ها کمک می‌کند تا به درستی با خطاها برخورد کنند.
  • ثبت خطاها: خطاها را در لاگ ثبت کنید تا بتوانید مشکلات را تشخیص و رفع کنید.
  • امنیت: هنگام مدیریت خطاها، به امنیت توجه کنید و از افشای اطلاعات حساس خودداری کنید.

مزایای مدیریت صحیح خطاها در APIهای RESTful:

  • بهبود تجربه کاربری: پاسخ‌های خطای واضح و مفید به کاربران کمک می‌کند تا مشکلات را سریع‌تر تشخیص دهند و رفع کنند.
  • سهولت در اشکال‌زدایی: ثبت خطاها و استفاده از استثناهای سفارشی به شما در تشخیص و رفع مشکلات کمک می‌کند.
  • امنیت بیشتر: مدیریت صحیح خطاها به جلوگیری از افشای اطلاعات حساس کمک می‌کند.
  • APIهای پایدارتر: APIهایی که به خوبی مدیریت خطا می‌شوند، پایدارتر و قابل اطمینان‌تر هستند.

با استفاده از ابزارها و تکنیک‌های مدیریت خطا در Flask-RESTful، می‌توانید APIهای RESTful قدرتمند و قابل اعتمادی ایجاد کنید.

احراز هویت و مجوز در Flask-RESTful: محافظت از API های شما

Flask-RESTful یک افزونه قدرتمند برای فریمورک Flask است که توسعه APIهای RESTful را تسهیل می‌کند. با این حال، برای ساخت APIهای امن و قابل اعتماد، باید مکانیزم‌های احراز هویت و مجوز را پیاده‌سازی کنیم. در این بخش، به بررسی این دو مفهوم و نحوه پیاده‌سازی آن‌ها در Flask-RESTful می‌پردازیم.

احراز هویت (Authentication)

احراز هویت فرآیندی است که طی آن، هویت یک کاربر یا سیستم تأیید می‌شود. در APIهای RESTful، احراز هویت معمولاً با استفاده از توکن‌های دسترسی (Access Token) انجام می‌شود. این توکن‌ها رشته‌های رمزنگاری شده‌ای هستند که حاوی اطلاعاتی درباره کاربر هستند.

روش‌های رایج احراز هویت در Flask-RESTful:

  • Basic Authentication: در این روش، نام کاربری و رمز عبور به صورت کدگذاری شده در هدر درخواست HTTP ارسال می‌شوند.
  • Token-Based Authentication: در این روش، یک توکن دسترسی به کاربر صادر می‌شود و کاربر این توکن را در هر درخواست به سرور ارسال می‌کند. توکن‌ها معمولاً با استفاده از الگوریتم‌های رمزنگاری قوی تولید می‌شوند.
  • OAuth 2.0: یک پروتکل استاندارد برای احراز هویت و مجوز است که به کاربران اجازه می‌دهد به منابع شخص ثالث دسترسی پیدا کنند.

پیاده‌سازی احراز هویت در Flask-RESTful:

برای پیاده‌سازی احراز هویت در Flask-RESTful، معمولاً از افزونه‌های جانبی مانند Flask-JWT-Extended استفاده می‌شود. این افزونه امکان ایجاد و مدیریت توکن‌های دسترسی، تأیید اعتبار آن‌ها و محافظت از منابع را فراهم می‌کند.

مجوز (Authorization)

مجوز فرآیندی است که تعیین می‌کند یک کاربر مجاز به انجام چه عملیاتی است. پس از احراز هویت کاربر، باید بررسی شود که آیا کاربر مجاز به انجام عملیاتی خاص است یا خیر.

روش‌های رایج مجوز در Flask-RESTful:

  • Role-Based Access Control (RBAC): در این روش، به کاربران نقش‌هایی مانند مدیر، کاربر عادی و غیره اختصاص داده می‌شود و هر نقش به یک مجموعه از مجوزها دسترسی دارد.
  • Permission-Based Access Control (PBAC): در این روش، به کاربران مجوزهای خاصی برای انجام عملیات مشخصی داده می‌شود.

پیاده‌سازی مجوز در Flask-RESTful:

برای پیاده‌سازی مجوز در Flask-RESTful، می‌توان از دکوراتورهای سفارشی استفاده کرد. این دکوراتورها قبل از اجرای هر متد از یک Resource فراخوانی می‌شوند و می‌توانند مجوزهای مورد نیاز برای دسترسی به آن متد را بررسی کنند.

مثال ساده احراز هویت و مجوز با Flask-JWT-Extended

Python
from flask import Flask
from flask_restful import Resource, Api
from flask_jwt_extended import JWTManager, jwt_required, current_user

app = Flask(__name__)
api = Api(app)
jwt = JWTManager(app)

# ... (تنظیمات JWT)

class ProtectedResource(Resource):
    @jwt_required()
    def get(self):
        return {'hello': f'Hello, {current_user.username}!'}

api.add_resource(ProtectedResource, '/protected')

در این مثال، از دکوراتور jwt_required() برای محافظت از Resource استفاده شده است. تنها کاربران دارای توکن معتبر می‌توانند به این Resource دسترسی پیدا کنند.

نکات مهم:

  • امنیت: هنگام پیاده‌سازی احراز هویت و مجوز، به امنیت بسیار توجه کنید. از الگوریتم‌های رمزنگاری قوی استفاده کنید و اطلاعات حساس را به صورت رمزنگاری شده ذخیره کنید.
  • سادگی: سعی کنید مکانیزم احراز هویت و مجوز را ساده و قابل فهم نگه دارید.
  • انعطاف‌پذیری: مکانیزم احراز هویت و مجوز شما باید به اندازه کافی انعطاف‌پذیر باشد تا بتوانید آن را در آینده توسعه دهید.

جمع‌بندی:

احراز هویت و مجوز دو جنبه بسیار مهم در امنیت APIها هستند. Flask-RESTful و افزونه‌های جانبی مانند Flask-JWT-Extended ابزارهای قدرتمندی برای پیاده‌سازی این مکانیزم‌ها در اختیار شما قرار می‌دهند. با پیاده‌سازی صحیح احراز هویت و مجوز، می‌توانید APIهای امن و قابل اعتماد ایجاد کنید.

 

استفاده از پایگاه داده با Flask-RESTful: یک راهنمای جامع

Flask-RESTful ابزاری قدرتمند برای ساخت APIهای RESTful با پایتون است. برای مدیریت داده‌های API، معمولاً به یک پایگاه داده نیاز داریم. در این بخش، نحوه اتصال Flask-RESTful به یک پایگاه داده و انجام عملیات CRUD (ایجاد، خواندن، به‌روزرسانی، حذف) را بررسی می‌کنیم.

انتخاب ORM

برای ارتباط بین پایتون و پایگاه داده، معمولاً از یک ORM (Object-Relational Mapper) استفاده می‌شود. ORM به شما اجازه می‌دهد با اشیاء پایتون با پایگاه داده تعامل کنید. یکی از محبوب‌ترین ORMها برای پایتون، SQLAlchemy است.

مراحل اتصال به پایگاه داده

  1. نصب وابستگی‌ها:

    Bash
    pip install Flask Flask-RESTful SQLAlchemy
    
  2. ایجاد فایل app.py:

    Python
    from flask import Flask
    from flask_restful import Resource, Api
    from flask_sqlalchemy import SQLAlchemy
    
    app = Flask(__name__)
    app.config['SQLALCHEMY_DATABASE_URI'] = 'postgresql://user:password@host:port/database'
    db = SQLAlchemy(app)
    
    # تعریف مدل‌های پایگاه داده
    class User(db.Model):
        id = db.Column(db.Integer, primary_key=True)
        username = db.Column(db.String(۸۰), unique=True, nullable=False)
        email = db.Column(db.String(۱۲۰), unique=True, nullable=False)
    
    # ایجاد جداول در پایگاه داده
    with app.app_context():
        db.create_all()
    
    # تعریف منابع (Resources)
    class UserList(Resource):
        # ...
    
    api = Api(app)
    api.add_resource(UserList, '/users')
    
    if __name__ == '__main__':
        app.run(debug=True)
    
  3. تعریف مدل‌ها:

    • کلاس User یک مدل پایگاه داده را تعریف می‌کند که شامل فیلدهای id, username و email است.
    • هر مدل در SQLAlchemy یک جدول در پایگاه داده را نشان می‌دهد.
  4. ایجاد جداول:

    • با اجرای db.create_all(), جداول مورد نظر در پایگاه داده ایجاد می‌شوند.
  5. تعریف منابع:

    • کلاس UserList یک Resource را تعریف می‌کند که عملیات CRUD را روی جدول کاربران انجام می‌دهد.

عملیات CRUD

  • خواندن (Read):
    Python
    def get(self):
        users = User.query.all()
        return jsonify({'users': [user.json() for user in users]})
    
  • ایجاد (Create):
    Python
    def post(self):
        data = request.get_json()
        new_user = User(username=data['username'], email=data['email'])
        db.session.add(new_user)
        db.session.commit()
        return {'message': 'User created successfully'}, ۲۰۱
    
  • بروزرسانی (Update):
    Python
    def put(self, user_id):
        user = User.query.get(user_id)
        if user is None:
            abort(۴۰۴)
        data = request.get_json()
        user.username = data['username']
        user.email = data['email']
        db.session.commit()
        return {'message': 'User updated successfully'}
    
  • حذف (Delete):
    Python
    def delete(self, user_id):
        user = User.query.get(user_id)
        if user is None:
            abort(۴۰۴)
        db.session.delete(user)
        db.session.commit()
        return {'message': 'User deleted successfully'}
    

نکات مهم

  • اعتبارسنجی داده‌ها: قبل از ذخیره داده‌ها در پایگاه داده، حتماً آن‌ها را اعتبارسنجی کنید.
  • مدیریت خطاها: برای مدیریت خطاها، از try-except و کدهای وضعیت HTTP مناسب استفاده کنید.
  • امنیت: از روش‌های امن برای ذخیره رمزهای عبور و سایر اطلاعات حساس استفاده کنید.
  • مقیاس‌پذیری: برای برنامه‌های بزرگ‌تر، به مقیاس‌پذیری پایگاه داده و API خود توجه کنید.

مزایای استفاده از Flask-RESTful و SQLAlchemy:

  • سادگی استفاده: با استفاده از ORM، کار با پایگاه داده بسیار ساده می‌شود.
  • سازگاری: Flask-RESTful و SQLAlchemy به خوبی با هم کار می‌کنند.
  • انعطاف‌پذیری: می‌توانید مدل‌های پیچیده‌تری را تعریف کرده و روابط بین آن‌ها را ایجاد کنید.
  • جامعه بزرگ: هر دو فریمورک دارای جامعه‌های بزرگی هستند که می‌توانید از آن‌ها کمک بگیرید.

با استفاده از Flask-RESTful و SQLAlchemy، می‌توانید APIهای RESTful قدرتمند و قابل سفارشی‌سازی برای برنامه‌های خود ایجاد کنید.

 

 

۵/۵ ( ۱ امتیاز )
نمایش بیشتر

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

دکمه بازگشت به بالا