Serializer.is_valid() возвращает 500 Внутренняя ошибка сервера

Я новичок в Django и у меня проблемы с созданием django-rest-framework API для post, наследующего APIView. Я использую сериализатор, который наследует djangos ModelSerializer. Я вижу 500 Internal server error всякий раз, когда пытаюсь проверить сериализатор.

color.js размещает изображение, используя фреймворк Django rest следующим образом.

function PersonalColorScreen({navigation,route}) {
    const {image} = route.params;
    console.log('uri is', image.uri);
    const [userToken, setUserToken] = React.useState(route.params?.userToken);

    const requestHeaders = {
        headers: {
            "Content-Type": "multipart/form-data"
        }
    }
    // helper function: generate a new file from base64 String
    //convert base64 image data to file object to pass it onto imagefield of serializer.
    //otherwise, serializer outputs 500 Internal server error code

    const dataURLtoFile = (dataurl, filename) => {
    const arr = dataurl.split(',')
    const mime = arr[0].match(/:(.*?);/)[1]
    const bstr = atob(arr[1])
    let n = bstr.length
    const u8arr = new Uint8Array(n)
    while (n) {
      u8arr[n - 1] = bstr.charCodeAt(n - 1)
      n -= 1 // to make eslint happy
    }
    return new File([u8arr], filename, { type: mime })
  }
  //random number between 0-9
  function getRandomInt(max) {
    return Math.floor(Math.random() * max);
  }
  
  // generate file from base64 string
  const file = dataURLtoFile(image.uri, `${getRandomInt(10)}.png`)
  const formData= new FormData();
  formData.append('img',file,file.name);

  console.log(file.name);
    //axios post request to send data
    // axios.post('http://localhost:8000/accounts/personalcolor/',  formData,requestHeaders)
    //multipartparser
    axios.post('http://localhost:8000/accounts/personalcolor/', formData, requestHeaders)
    .then(res => {
        console.log(res);
        if (res.data === 'upload another image') {
            setimageError('upload another image');
        } else {
            // signUp(userToken);
            let color;
            switch (res.data){
                case ('spring'):
                    color = 'spring';
                    break;
                case ('summer'):
                    color = 'summer';
                    break;
                case ('fall'):
                    color = 'fall';
                    break;
                case ('winter'):
                    color = 'winter';
                    break;
            }
        }
        })
    .catch(err => {
        console.error(err.response.data)
    })

view.py обрабатывает размещенное изображение. Я пытаюсь сохранить сериализатор для сохранения изображения внутри папки media. Путь к изображению должен быть извлечен.

@api_view(['POST'])
def personalcolor(request):

serializer = ColorSerializer(request.data)
# validation of input data
if serializer.is_valid():
    # serializer.save()
    return Response(serializer.data, status = status.HTTP_201_CREATED)
else:
    return Response(serializer.errors, status = status.HTTP_400_BAD_REQUEST)

model.py

class Personalcolor(models.Model):
    objects = models.Manager()
    img = models.ImageField('personal_img',upload_to="personalcolor/", blank=True)

serializer.py

class ColorSerializer(serializers.ModelSerializer):
   class Meta:
      model = Personalcolor
      fields = ('img',)

Выполнение кода возвращает "Failed to load resource: the server responded with a status of 500 (Internal Server Error)". Я думаю, что что-то не так с сериализатором, но не смог разобраться даже после поиска в Интернете. Любая помощь будет очень признательна.

Проверьте правильность формата JSON, который вы отправляете. Ключ json должен совпадать с именем поля вашей модели... Он должен быть точно таким, как структурировано имя поля вашей модели.

А в вашем Serializer измените;

fields = ('img')

To

fields = ['img']

Если вы хотите вернуть все экземпляры модели, используйте;

fields = '__all__'

Вернуться на верх