Rumah >pembangunan bahagian belakang >Tutorial Python >Persediaan Projek API Django
Baiklah, mari mulakan pengekodan! ini adalah artikel pengekodan pertama selepas memperkenalkan idea Alive Diary dan membuktikan Gemini boleh menjadi jiwa, kami akan mula mengekod Backend dengan Django.
Untuk memastikan perkara itu teratur, saya akan membincangkan projek itu melalui berbilang artikel, jadi artikel ini
Saya akan cuba mengupas sebanyak mungkin butiran tanpa membosankan anda, tetapi saya masih mengharapkan anda membiasakan diri dengan beberapa aspek Python dan Django.
versi akhir kod sumber boleh didapati di https://github.com/saad4software/alive-diary-backend
Semak artikel sebelum ini jika berminat!
Selepas memasang Python, dan menyediakan persekitaran maya yang sesuai dengan sistem pengendalian anda. pastikan anda memasang perpustakaan tersebut
Django==4.2.16 # it is django itself! django-cors-headers==4.4.0 # avoid cors-headers issues django-filter==24.3 # easily filter text fields djangorestframework==3.15.2 # rest framework! djangorestframework-simplejwt==5.3.1 # JWT token pillow==10.4.0 # for images python-dotenv==1.0.1 # load config from .env file google-generativeai==0.7.2 # google api ipython==8.18.1 # process gemini responses django-parler==2.3 # multiple languages support django-parler-rest==2.2 # multi-language with restframework
keperluan.txt
Ia tidak semestinya versi yang sama, bergantung pada versi Python anda, anda boleh memasang setiap satu secara manual menggunakan
pip pasang django
atau buat fail keperluan dan gunakan fail lama yang sama
pip install -r requirements.txt
Dengan django dan perpustakaan dipasang, kami boleh memulakan projek kami
django-admin startproject alive_diary cd alive_diary python manage.py startapp app_account python manage.py startapp app_admin python manage.py startapp app_main
Kami mencipta projek yang dipanggil "alive_diary" dan di dalamnya, kami mencipta tiga aplikasi,
Kami akan mengekalkan pergantungan minimum antara apl Django untuk menjadikannya boleh digunakan semula dalam projek lain.
Ringkasnya, ini ialah fail tetapan terakhir, mari kita berjalan dengan pantas melaluinya
import os from datetime import timedelta from pathlib import Path from dotenv import load_dotenv
Kami telah menggunakan timedelta daripada pakej datetime untuk menetapkan JWT seumur hidup, os dan load_dotenv untuk memuatkan pembolehubah daripada fail .env.
load_dotenv()
muat pembolehubah daripada fail .env
BASE_DIR = Path(__file__).resolve().parent.parent SECRET_KEY = os.getenv("SECRET_KEY") DEBUG = True ALLOWED_HOSTS = ['*']
menambah '*' untuk ALLOWED_HOSTS untuk membenarkan sambungan dari mana-mana IP. os.getenv dapatkan nilai kunci daripada fail .env.
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'corsheaders', 'rest_framework', 'django_filters', 'app_account', 'app_admin', 'app_main', ]
Menambahkan corsheaders, rest_framework dan apl django_filters serta tiga apl kami, app_account, app_admin dan app_main.
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
Jangan lupa untuk menambah perkakas tengah CorsMiddleware sebelum CommonMiddleware
Django==4.2.16 # it is django itself! django-cors-headers==4.4.0 # avoid cors-headers issues django-filter==24.3 # easily filter text fields djangorestframework==3.15.2 # rest framework! djangorestframework-simplejwt==5.3.1 # JWT token pillow==10.4.0 # for images python-dotenv==1.0.1 # load config from .env file google-generativeai==0.7.2 # google api ipython==8.18.1 # process gemini responses django-parler==2.3 # multiple languages support django-parler-rest==2.2 # multi-language with restframework
menambahkan konfigurasi pengepala cors pada fail tetapan
django-admin startproject alive_diary cd alive_diary python manage.py startapp app_account python manage.py startapp app_admin python manage.py startapp app_main
Gunakan Pengesahan JWT Mudah sebagai kelas pengesahan lalai untuk perpustakaan rangka kerja rehat.
import os from datetime import timedelta from pathlib import Path from dotenv import load_dotenv
tukar kelas pengguna lalai kepada kelas tersuai daripada app_account, kami belum mencipta model ini lagi.
load_dotenv()
Menambahkan bahasa yang disokong dan tetapkan folder untuk fail dan statik
BASE_DIR = Path(__file__).resolve().parent.parent SECRET_KEY = os.getenv("SECRET_KEY") DEBUG = True ALLOWED_HOSTS = ['*']
Tetapan e-mel, untuk proses pengesahan e-mel. kami sedang memuatkannya daripada fail .env.
INSTALLED_APPS = [ 'django.contrib.admin', 'django.contrib.auth', 'django.contrib.contenttypes', 'django.contrib.sessions', 'django.contrib.messages', 'django.contrib.staticfiles', 'corsheaders', 'rest_framework', 'django_filters', 'app_account', 'app_admin', 'app_main', ]
Tetapan token JWT yang mudah, kami menetapkan jangka hayat token akses "ACCESS_TOKEN_LIFETIME" menjadi 8 jam dan muat semula token sepanjang hayat "REFRESH_TOKEN_LIFETIME" menjadi 5 hari. kami sedang memutarkan token muat semula (menghantar token muat semula baharu dengan setiap permintaan token muat semula) "ROTATE_REFRESH_TOKENS" dan menggunakan awalan pengepala 'Pembawa' untuk pengesahan "AUTH_HEADER_TYPES".
Vars yang digunakan dalam fail .env hendaklah
MIDDLEWARE = [ 'django.middleware.security.SecurityMiddleware', 'django.contrib.sessions.middleware.SessionMiddleware', 'corsheaders.middleware.CorsMiddleware', 'django.middleware.common.CommonMiddleware', 'django.middleware.csrf.CsrfViewMiddleware', 'django.contrib.auth.middleware.AuthenticationMiddleware', 'django.contrib.messages.middleware.MessageMiddleware', 'django.middleware.clickjacking.XFrameOptionsMiddleware', ]
tetapkan nilai mengikut projek anda, anda boleh menggunakan kunci rahsia django yang dijana untuk Kunci Rahsia, dapatkan kunci API Google Gemini daripada studio AI dan gunakan akaun e-mel anda untuk e-mel pengesahan.
menggunakan akaun google untuk menghantar e-mel adalah mungkin, tetapi tidak disyorkan. tetapan hendaklah seperti
ROOT_URLCONF = 'alive_diary.urls' TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [], 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.contrib.auth.context_processors.auth', 'django.contrib.messages.context_processors.messages', ], }, }, ] WSGI_APPLICATION = 'alive_diary.wsgi.application' DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': BASE_DIR / 'db.sqlite3', } } AUTH_PASSWORD_VALIDATORS = [ { 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator', }, { 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator', }, { 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator', }, { 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator', }, ] LANGUAGE_CODE = 'en-us' TIME_ZONE = 'UTC' USE_I18N = True USE_L10N = True USE_TZ = True STATIC_URL = '/static/' DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField' # CORS HEADERS CORS_ORIGIN_ALLOW_ALL = True CORS_ALLOW_CREDENTIALS = True
dan pengguna harus mendayakan "Apl yang kurang selamat" untuk mengakses akaun gmail. Bagaimanapun, kita boleh membina semuanya dahulu, dan bimbang tentang perkara ini kemudian. abaikan sahaja bahagian pengesahan e-mel buat masa ini.
Hanya untuk dapat menjalankan projek dan menyelesaikan artikel ini, mari buat model pengguna dalam app_account/models.py
REST_FRAMEWORK = { 'DEFAULT_AUTHENTICATION_CLASSES': [ 'rest_framework_simplejwt.authentication.JWTAuthentication', ], }
semudah itu! (kami akan mengusahakannya pada artikel seterusnya) mari berhijrah dan berhijrah
AUTH_USER_MODEL = 'app_account.User'
jika semuanya berjalan lancar, anda sepatutnya dapat menjalankan projek sekarang dengan
LANGUAGES = [ ('en', 'English'), ('ar', 'Arabic') ] STATICFILES_DIRS = [os.path.join(BASE_DIR, "app_main", "site_static")] STATIC_ROOT = os.path.join(BASE_DIR, "app_main", "static") MEDIA_ROOT = os.path.join(BASE_DIR, "app_main", "media") MEDIA_URL = "/app_main/media/"
Sila kongsi sebarang isu yang anda hadapi dengan saya. Kami bersedia untuk mula bekerja pada apl projek sekarang!
artikel seterusnya hendaklah merangkumi app_account, apl pengurusan pengguna, ia termasuk pengurusan pengguna, log masuk, daftar, tukar kata laluan, terlupa kata laluan, pengesahan akaun dan tindakan berkaitan pengguna lain yang kami perlukan dalam kebanyakan apl.
Nantikan ?
Atas ialah kandungan terperinci Persediaan Projek API Django. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!