mirror of
https://github.com/lemeow125/Notes.git
synced 2025-02-23 22:48: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
57 lines
No EOL
2.4 KiB
Markdown
57 lines
No EOL
2.4 KiB
Markdown
### API App
|
|
|
|
When writing backend APIs, you make changes to your app that may not be compatible with older versions.
|
|
|
|
Examples of these include the following;
|
|
|
|
- You changed what should be sent to your login API in order to authenticate with a newer version of your backend
|
|
- When requesting books from your database, a newer version of your API may return a different format (XML instead of JSON)
|
|
|
|
You should take this into account when building a new project, otherwise users on older versions may encounter errors.
|
|
|
|
data:image/s3,"s3://crabby-images/0857e/0857e2bccd0f713b3ccc667e949f9a8eac93904a" alt="3b993b4fb30752dbd22c157c4c852f82_MD5"
|
|
|
|
This lets you allow users on older versions to still use your app (v1) while allowing newer users without any overlap (v2)
|
|
|
|
We will structure your project in the same manner as above. Create a folder named `api` in your Django project folder besides **config**
|
|
|
|
data:image/s3,"s3://crabby-images/68abb/68abb6124c7d33bd1bf8158b6d3ff6bac184ee42" alt="e4b384b960e31b256a53775aa6f61ff2_MD5"
|
|
|
|
Create the following files inside the `api` folder
|
|
|
|
- `__init__.py`
|
|
- `urls.py`
|
|
|
|
data:image/s3,"s3://crabby-images/bc69c/bc69ceb0555d4309377e403d9547a1b085f71d9f" alt="8357583c43ac252db3811fcc35f21564_MD5"
|
|
Leave **\_\_init\_\_.py** blank. Instead, open **urls.py** and add the following code
|
|
|
|
```python
|
|
from django.contrib import admin
|
|
from django.urls import path
|
|
|
|
urlpatterns = [
|
|
path('admin/', admin.site.urls),
|
|
]
|
|
```
|
|
|
|
We will then need to point the main config's url file **(url.py)** to the one we just created. Open the **urls.py** file in the **config** folder, replace it with the following
|
|
|
|
```python
|
|
from django.urls import path, include
|
|
|
|
urlpatterns = [
|
|
path('api/v1/', include('api.urls')),
|
|
]
|
|
```
|
|
|
|
Your setup should then look like this
|
|
|
|
[data:image/s3,"s3://crabby-images/0128d/0128d3f66f9266798003579d571217d9d09cfdbc" alt="8a1e35b34d95be992bd550b32bfe03fa_MD5"](https://bookstack.06222001.xyz/uploads/images/gallery/2024-09/2gZimage.png)
|
|
|
|
[data:image/s3,"s3://crabby-images/2140f/2140f2d47feef28d2468dd60a17b6088ccd9473f" alt="f9a1c18b83ca805afb4662e6ba43eca2_MD5"](https://bookstack.06222001.xyz/uploads/images/gallery/2024-09/70bimage.png)
|
|
|
|
There is no need to include the **api** app in your **INSTALLED\_APPS (config/settings.py)**
|
|
|
|
The next section will handle users and authentication
|
|
|
|
Up Next: [5 - User Setup and Migrations](5%20-%20User%20Setup%20and%20Migrations.md) |