Django URL问题,同时调用Postman

iqjalb3h  于 2024-01-07  发布在  Postman
关注(0)|答案(2)|浏览(308)

我正在Django,REST API和Mongo DB中创建CRUD操作。我已经完成了基本的CRUD代码。当我尝试在postman中调用API时,我没有得到任何响应。在pycharm中,我看到以下问题,

  1. "POST /emp/registration%0A HTTP/1.1" 404 2297
  2. Not Found: /emp/registration

字符串
这是我的项目结构。
x1c 0d1x的数据
DjangoAPI.urls.py**

  1. from django.urls import path
  2. from django.urls import re_path
  3. from django.conf.urls import include
  4. urlpatterns = [
  5. path('admin/', admin.site.urls),
  6. path('emp/', include('EmployeeApp.urls')),
  7. ]

DjangoAPI. DjangeApp.urls.py

  1. from EmployeeApp import views
  2. from django.conf.urls.static import static
  3. from django.conf import settings
  4. from django.urls import path
  5. urlpatterns = [
  6. path('registration', views.registrationApi),
  7. ]

DjangoAPI.settings.py

  1. Generated by 'django-admin startproject' using Django 3.2.4.
  2. For more information on this file, see
  3. https://docs.djangoproject.com/en/3.2/topics/settings/
  4. For the full list of settings and their values, see
  5. https://docs.djangoproject.com/en/3.2/ref/settings/
  6. """
  7. from pathlib import Path
  8. import os
  9. BASE_DIR=Path(__file__).resolve(strict=True).parent.parent
  10. MEDIA_URL='/Photos/'
  11. MEDIA_ROOT=os.path.join(BASE_DIR,"Photos")
  12. # Build paths inside the project like this: BASE_DIR / 'subdir'.
  13. BASE_DIR = Path(__file__).resolve().parent.parent
  14. # Quick-start development settings - unsuitable for production
  15. # See https://docs.djangoproject.com/en/3.2/howto/deployment/checklist/
  16. # SECURITY WARNING: keep the secret key used in production secret!
  17. SECRET_KEY = 'django-insecure-@oxx-o(4f=mxha%-tlv97)x9m7x_fw=(@*k=*29q%r7c8*)%-&'
  18. # SECURITY WARNING: don't run with debug turned on in production!
  19. DEBUG = True
  20. ALLOWED_HOSTS = []
  21. # Application definition
  22. INSTALLED_APPS = [
  23. 'django.contrib.admin',
  24. 'django.contrib.auth',
  25. 'django.contrib.contenttypes',
  26. 'django.contrib.sessions',
  27. 'django.contrib.messages',
  28. 'django.contrib.staticfiles',
  29. 'rest_framework',
  30. 'corsheaders',
  31. 'EmployeeApp.apps.EmployeeappConfig'
  32. ]
  33. CORS_ORIGIN_ALLOW_ALL = True
  34. MIDDLEWARE = [
  35. 'corsheaders.middleware.CorsMiddleware',
  36. 'django.middleware.security.SecurityMiddleware',
  37. 'django.contrib.sessions.middleware.SessionMiddleware',
  38. 'django.middleware.common.CommonMiddleware',
  39. 'django.middleware.csrf.CsrfViewMiddleware',
  40. 'django.contrib.auth.middleware.AuthenticationMiddleware',
  41. 'django.contrib.messages.middleware.MessageMiddleware',
  42. 'django.middleware.clickjacking.XFrameOptionsMiddleware',
  43. ]
  44. ROOT_URLCONF = 'DjangoAPI.urls'
  45. TEMPLATES = [
  46. {
  47. 'BACKEND': 'django.template.backends.django.DjangoTemplates',
  48. 'DIRS': [],
  49. 'APP_DIRS': True,
  50. 'OPTIONS': {
  51. 'context_processors': [
  52. 'django.template.context_processors.debug',
  53. 'django.template.context_processors.request',
  54. 'django.contrib.auth.context_processors.auth',
  55. 'django.contrib.messages.context_processors.messages',
  56. ],
  57. },
  58. },
  59. ]
  60. WSGI_APPLICATION = 'DjangoAPI.wsgi.application'
  61. # Database
  62. # https://docs.djangoproject.com/en/3.2/ref/settings/#databases
  63. DATABASES = {
  64. 'default': {
  65. 'ENGINE': 'djongo',
  66. 'CLIENT': {
  67. "host":"mongodb+srv://xxxxx:[email protected]/?retryWrites=true&w=majority"
  68. ,"name":"expense_tracker_v2",
  69. "authMechanism":"SCRAM-SHA-1" #For atlas cloud db
  70. }
  71. }
  72. }
  73. # Password validation
  74. # https://docs.djangoproject.com/en/3.2/ref/settings/#auth-password-validators
  75. AUTH_PASSWORD_VALIDATORS = [
  76. {
  77. 'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
  78. },
  79. {
  80. 'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
  81. },
  82. {
  83. 'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
  84. },
  85. {
  86. 'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
  87. },
  88. ]
  89. # Internationalization
  90. # https://docs.djangoproject.com/en/3.2/topics/i18n/
  91. LANGUAGE_CODE = 'en-us'
  92. TIME_ZONE = 'UTC'
  93. USE_I18N = True
  94. USE_L10N = True
  95. USE_TZ = True
  96. # Static files (CSS, JavaScript, Images)
  97. # https://docs.djangoproject.com/en/3.2/howto/static-files/
  98. STATIC_URL = '/static/'
  99. # Default primary key field type
  100. # https://docs.djangoproject.com/en/3.2/ref/settings/#default-auto-field
  101. DEFAULT_AUTO_FIELD = 'django.db.models.BigAutoField'

models.py

  1. from django.db import models
  2. class Registrations(models.Model):
  3. RegistrationId = models.AutoField(primary_key=True)
  4. Username = models.CharField(max_length=200, unique=True)
  5. Email = models.EmailField(unique=True)
  6. Password = models.CharField(max_length=200)

views.py

  1. from django.shortcuts import render
  2. from django.views.decorators.csrf import csrf_exempt
  3. from rest_framework.parsers import JSONParser
  4. from django.http.response import JsonResponse
  5. from EmployeeApp.models import Registrations
  6. from EmployeeApp.serializers import RegistrationsSerializer
  7. @csrf_exempt
  8. def registrationApi(request, id=0):
  9. if request.method == 'GET':
  10. registrations = Registrations.objects.all()
  11. departments_serializer = RegistrationsSerializer(registrations, many=True)
  12. return JsonResponse(departments_serializer.data, safe=False)
  13. elif request.method == 'POST':
  14. department_data = JSONParser().parse(request)
  15. departments_serializer = RegistrationsSerializer(data=department_data)
  16. if departments_serializer.is_valid():
  17. departments_serializer.save()
  18. return JsonResponse("Added Successfully", safe=False)
  19. return JsonResponse("Failed to Add", safe=False)
  20. elif request.method == 'PUT':
  21. department_data = JSONParser().parse(request)
  22. department = Registrations.objects.get(DepartmentId=department_data['DepartmentId'])
  23. departments_serializer = RegistrationsSerializer(department, data=department_data)
  24. if departments_serializer.is_valid():
  25. departments_serializer.save()
  26. return JsonResponse("Updated Successfully", safe=False)
  27. return JsonResponse("Failed to Update")
  28. elif request.method == 'DELETE':
  29. department = Registrations.objects.get(DepartmentId=id)
  30. department.delete()
  31. return JsonResponse("Deleted Successfully", safe=False)


如果我在Postman(PUT)方法中调用这个[http://127.0.0.1:8080/emp/registration][2] url,我会得到url not found错误。
这是我的数据:

  1. {
  2. "Username":"Soban",
  3. "Email":"[email protected]",
  4. "Password":"soban"
  5. }


我如何做CRUD操作?任何帮助都将非常感谢。

错误信息:

“POST /emp/registration%0A HTTP/1.1”404 2297 Not Found:/emp/registration
http://127.0.0.1:8080/emp/registration

nkhmeac6

nkhmeac61#

问题是DjangoAPI.EmployeeApp.urls.py中没有一个路径看起来像您从Postman中调用的URL。路径列表需要添加另一个模式,当它包含ID时匹配路径,就像您在PUT调用中使用的那样。

  1. urlpatterns = [
  2. path('registration', views.registrationApi),
  3. path('registration/<int:id>', views.registrationApi),
  4. ]

字符串
第二个路径包含<int:id>,它告诉Django它应该捕获位于路径中该位置的整数,并将其作为关键字参数id发送到视图。包含多个都指向同一视图的路径是一种常见的方式,允许某些调用(如PUT)使用可选参数,而其他调用(如POST)则不使用。
在Django文档中阅读更多:https://docs.djangoproject.com/en/4.2/ref/urls/

qhhrdooz

qhhrdooz2#

考虑用正斜杠结束路径。

  1. urlpatterns = [
  2. •••
  3. path('registration/', views.registrationApi),
  4. •••
  5. ]

字符串

相关问题