How to Build a CRUD App with Python?
In this tutorial, you'll learn to construct a basic CRUD (create, read, update, delete) application using Python.
We will harness Back4app as the backend platform to simplify your data management. This guide walks you through setting up a Back4app project, creating a flexible data schema, and coding Python scripts to execute CRUD operations via REST API calls.
Initially, you will establish a Back4app project called Basic-CRUD-App-Python that provides a scalable, non-relational data storage solution.
You will outline your data model by defining classes and their fields, either manually through the Back4app dashboard or with the assistance of the integrated AI Agent.
Next, you will explore the Back4app Admin App, a drag-and-drop interface that simplifies managing your data.
Finally, you'll link your Python application to Back4app by making RESTful API calls to perform secure CRUD operations.
After completing this guide, you'll have developed a production-ready Python application that performs core CRUD tasks along with secure user authentication and data management.
- How to create a Python-based CRUD app with a robust, non-relational backend.
- Techniques for building and integrating a scalable backend with your Python code.
- How to efficiently use the Back4app Admin App for managing data records.
- Deployment approaches, including containerization with Docker for your Python application.
Ensure you have the following before proceeding:
- A Python development setup. Use your preferred IDE (such as PyCharm or VS Code) and ensure Python 3.7+ is installed.
- Basic understanding of Python, object-oriented programming, and REST APIs. Refer to the Python documentation if needed.
- Log into your Back4app account.
- Select the “New App” button on your dashboard.
- Input the project name: Basic-CRUD-App-Python and follow the prompts to complete the setup.
data:image/s3,"s3://crabby-images/6ba01/6ba013a30a925ba47c5f46147a51c22c8ff0854e" alt="Create New Project Create New Project"
Once set up, your project appears on the dashboard, laying the foundation for your backend configuration.
For this CRUD application, you need to define multiple classes (collections) in your Back4app project. The examples below outline the essential classes and their corresponding fields needed for basic CRUD operations.
This class stores information about each item.
Field | Data Type | Description |
---|---|---|
_id | ObjectId | Automatically generated unique identifier. |
title | String | Name of the item. |
description | String | Brief overview of the item. |
createdAt | Date | Timestamp marking when the item was created. |
updatedAt | Date | Timestamp marking the last modification. |
This class handles user credentials and authentication.
Field | Data Type | Description |
---|---|---|
_id | ObjectId | Auto-generated unique identifier. |
username | String | Unique username for the user. |
String | User's unique email address. | |
passwordHash | String | Hashed password for secure authentication. |
createdAt | Date | Timestamp when the account was created. |
updatedAt | Date | Timestamp when the account was last updated. |
You can manually create these classes and specify fields through the Back4app dashboard.
data:image/s3,"s3://crabby-images/ea8f7/ea8f7acbf7926d5edbfe766e0b8a9796e2b21a35" alt="Create New Class Create New Class"
You add fields by choosing a data type, naming the field, setting default values, and marking it as required.
data:image/s3,"s3://crabby-images/5ebf5/5ebf53a415498f9ed1993ff3ecd97616ee7fed12" alt="Create Column Create Column"
The Back4app AI Agent is a smart tool embedded in your dashboard that can auto-generate your data schema based on your requirements. This feature accelerates project setup and guarantees that your model supports all necessary CRUD functions.
- Open the AI Agent: Sign in to your Back4app dashboard and navigate to the AI Agent in your project settings.
- Outline Your Data Model: Provide a comprehensive description detailing the classes and fields needed.
- Review and Confirm: The AI Agent will propose a schema based on your input. Examine the suggestion and confirm to implement it.
This approach saves time and ensures that your data model is well-optimized for your application needs.
The Back4app Admin App is a no-code interface that allows you to manage your backend data efficiently. Its intuitive drag-and-drop features let you create, view, update, and delete records with ease.
- Go to the “More” menu on your Back4app dashboard.
- Select “Admin App” and click on “Enable Admin App.”
- Configure your admin account by setting up initial credentials. This will also create roles (like B4aAdminUser) and necessary system classes.
data:image/s3,"s3://crabby-images/9dd96/9dd961506f2fb580922f0db34aaf8828b4aa2ebb" alt="Enable Admin App Enable Admin App"
After enabling it, log in to the Admin App to manage your app's data.
data:image/s3,"s3://crabby-images/dfd40/dfd40bd7d239725fdb36932e4463a7669667f018" alt="Admin App Dashboard Admin App Dashboard"
Within the Admin App, you can:
- Insert Records: Choose “Add Record” in a class (e.g., Items) to add new data.
- View and Edit Records: Click on an entry to see its details or update fields.
- Remove Records: Delete records that are no longer needed.
This user-friendly interface makes managing data a breeze.
With your backend ready, the next phase is linking your Python application to Back4app.
Since an official Parse SDK for Python is not available, you will interact with Back4app using REST API calls. Python's requests library is perfect for this.
Run the following command to install the requests package:
Below is a Python script that retrieves items from your Back4app project:
Here are examples for the other CRUD operations:
Integrate these functions into your application logic as needed.
Protect your data by setting up access control rules. For instance, you can ensure that only the owner of an item can view or modify it by using specific ACL settings through your API calls.
When creating a private item, include ACL settings in your payload. Detailed configuration can be handled in your Back4app dashboard.
Adjust CLPs in your Back4app project settings to enforce default security policies, ensuring that only authenticated users have access to certain classes.
Back4app supports user authentication through its built-in User class. The following examples demonstrate how you can register and authenticate users using Python REST API calls.
This setup supports session management, password resets, and other authentication features.
Back4app provides a straightforward deployment process. You can deploy your Python application using methods such as Docker containerization.
- Package your Application: Use your preferred method (for instance, creating a virtual environment and packaging your code).
- Test the Package: Ensure that all dependencies are installed and your scripts are working as expected.
A typical Python project may look like:
For example, your crud.py might include the functions shown above for handling items.
To containerize your app, include a Dockerfile in your project directory:
- Connect Your GitHub Repository: Host your Python code on GitHub and link it to your Back4app account.
- Set Deployment Options: In the Back4app dashboard, navigate to the Web Deployment section, select your repository (e.g., Basic-CRUD-App-Python), and choose the branch.
- Configure Build Settings: Set the build command (e.g., pip install -r requirements.txt) and specify the startup command.
- Deploy Your App: Click Deploy and monitor the logs until your application is live.
Great job! You have successfully built a Python-based CRUD application integrated with Back4app.
You set up a project named Basic-CRUD-App-Python, defined classes for Items and Users, and managed your data via the Back4app Admin App.
Additionally, you connected your Python scripts to Back4app using REST API calls and implemented solid security measures.
Next Steps:
- Expand Your Application: Introduce additional features like advanced filtering, detailed views, or live updates.
- Enhance Backend Capabilities: Consider integrating cloud functions, external APIs, or advanced role-based access controls.
- Deepen Your Skills: Visit the Back4app documentation and explore more tutorials to refine your application.
Happy coding and enjoy building your Python CRUD application!
data:image/s3,"s3://crabby-images/d6cbc/d6cbc3c7cb2c07d5c2eec99d61272ccdddf11c27" alt="Doc contributor"