mirror of
https://github.com/lemeow125/Notes.git
synced 2025-02-23 14:38:08 +08:00
Affected files: docs/Guides/Django REST Framework/1 - Setup.md docs/Guides/Django REST Framework/2 - Initialize your First Project.md docs/Guides/Django REST Framework/3 - Project Structure.md docs/Guides/Django REST Framework/4 - REST Framework Setup.md docs/Guides/Django REST Framework/5 - User Setup and Migrations.md docs/Guides/Django REST Framework/6 - Django Admin.md docs/Guides/Django REST Framework/Django REST Framework.md
83 lines
No EOL
3.8 KiB
Markdown
83 lines
No EOL
3.8 KiB
Markdown
### Folder Hierarchy
|
|
|
|
Your project's root folder (the outer most) contains the following
|
|
|
|
- `Pipfile`, `Pipfile.lock` - to track your installed packages as mentioned previously
|
|
- `.gitignore` - to exempt some files from being tracked in your version control (Git)
|
|
|
|
#### Project Folder
|
|
|
|
data:image/s3,"s3://crabby-images/f6d1e/f6d1e755983eb15042d78e958fb9be1a9289a61f" alt="3a9acd103fc5ff4a63a7520951dc99b8_MD5"
|
|
|
|
The folder immediately proceeding your first one contains your Django project, created by the command `django-admin startproject PROJECT\_NAME` which you previously executed
|
|
|
|
This contains the following
|
|
|
|
- `manage.py` - The entry point to your Django app (e.g. the `python manage.py runserver` command and such)
|
|
- `db.sqlite3` - The default database file for Django, which uses [SQLite](https://www.sqlite.org/) (you can switch to PostgreSQL or MySQL later on)
|
|
- Another folder which contains your project's main config or app
|
|
|
|
#### Django Apps
|
|
|
|
|
|
Django divides your projects into groups called apps. When you start a new project, you start off with your first app.
|
|
|
|
In this case, my first app is named `djangobackend`
|
|
|
|
data:image/s3,"s3://crabby-images/bf0ed/bf0ed7caa5a98e5a6566e86935a4e135a454454e" alt="1f40b8e177d08862762cffe20f01e38f_MD5"
|
|
|
|
That seems a bit confusing doesn't it?
|
|
|
|
#### Renaming the Config App
|
|
|
|
To make things clearer, you can opt to rename the main app of your Django project. These are the changes you must make
|
|
|
|
- Rename the main app folder to `config`
|
|
|
|
data:image/s3,"s3://crabby-images/743e8/743e802398770180953bd6ec132b44e3bbaa29c3" alt="bd12032f298e0a3e9d7c12999b231b77_MD5"
|
|
|
|
- Open `asgi.py` and change line 14 to point to **config.settings** instead of **PROJECT_NAME.settings**
|
|
|
|
data:image/s3,"s3://crabby-images/28abd/28abdce861716e2d75ee958bd0fdffe473c04033" alt="9a3064d2cb4d17b632358d10dfbdcc22_MD5"
|
|
|
|
- Do the same for the `wsgi.py` file, also in line 14
|
|
|
|
data:image/s3,"s3://crabby-images/cdd08/cdd081d093eec87ac20438361e3f40f8d6c27789" alt="6846e765a92401a0768a60fab29151f9_MD5"
|
|
|
|
- Go to `settings.py` and set **ROOT_URLCONF** in line 52 to **config.urls** instead of **PROJECT_NAME.urls**
|
|
|
|
data:image/s3,"s3://crabby-images/e7109/e7109dc7ae52b71678804f960f6f75da36d2b12a" alt="8a0ab212600d24de9fb70656e810e603_MD5"
|
|
|
|
- Do the same for **WSGI_APPLICATION** in `settings.py`, line 70
|
|
|
|
data:image/s3,"s3://crabby-images/7a4e4/7a4e4e71d1d068849c3e8432fd919de802a7b7ec" alt="42ab80ce78c1158e8af47ddf9631c027_MD5"
|
|
|
|
- In `manage.py`, change line 19 to point to **config.settings** instead of **PROJECT_NAME.settings**
|
|
|
|
[data:image/s3,"s3://crabby-images/4057a/4057adf698b0c4939ea3426c928efb1a8a685079" alt="29904325362d967d3e9fe79941ae3589_MD5"
|
|
|
|
With that, you should be good to go. Double check your setup by starting the Django app once again
|
|
|
|
data:image/s3,"s3://crabby-images/bb2af/bb2afd64a66b2c2c61c9928ca024b7a8268cd16d" alt="d85a379bdec6197afff6e37bd79359a2_MD5"
|
|
|
|
If you followed everything correctly, you should see the same page as before
|
|
|
|
data:image/s3,"s3://crabby-images/8ac97/8ac974b44f75bd013d1c68d2c10a3b0f29772603" alt="9e9b9a07ac2b8066670d18d04a97627c_MD5"
|
|
|
|
### Setting up DRF
|
|
|
|
Your current setup only includes Django. To proceed with Django REST Framework, we will need to add it to our project.
|
|
|
|
You've already installed Django REST Framework in the previous steps (e.g. `pipenv install django djangorestframework`).
|
|
|
|
To register it as an app in our project. Open your `settings.py` file and look for the **INSTALLED_APPS** section
|
|
|
|
data:image/s3,"s3://crabby-images/89244/8924430924fbf0b09e3dd18ba23b6d28d82ebb5d" alt="5bc2f2801c226ade60ad52496486ff78_MD5"
|
|
|
|
Add **rest_framework** to **INSTALLED_APPS**
|
|
|
|
data:image/s3,"s3://crabby-images/9568b/9568b7b1aea2dfe910be4c6ebf943cc455ba28f8" alt="c327ae10edcfd245d0ad4cfe787bf9ae_MD5"
|
|
|
|
The next section will then tackle building a REST API with DRF.
|
|
|
|
Up Next: [4 - REST Framework Setup](4%20-%20REST%20Framework%20Setup.md) |