Вызовите MultiValueDictKeyError request.FILES, чтобы получить данные изображения base64 - PullRequest
0 голосов
/ 01 января 2019

На самом деле мне нужно получить данные base64-изображения, сгенерированные croppie библиотекой javascript.Данные изображения выглядят следующим образом.



Вот мой HTML

<form action="{% url 'profile' %}" enctype="multipart/form-data" method="post" class="pic-upload-form" id="form">{% csrf_token %}
      <div class="custom-file">
        {% bootstrap_form form %}
      </div>
      <!-- Croppie area -->
      <div id="upload-demo"></div>
      <input type="hidden" id="image-data" name="imagebase64">
      <button  type="button" class="btn btn-outline-info btn-custom upload-result">save</button>
 </form>

Последняя часть моего js, где я привязываю данные изображения к скрытому вводу.

$('.upload-result').on('click', function (ev) {
    $uploadCrop.croppie('result', {
        type: 'base64',
        size: 'viewport'
    }).then(function (src) {
         console.log(src);

         // bind the image data to the hidden inpu id image-data
         $('#image-data').attr('src', src);
         $('#form').submit();
    });
});

А вот мое мнение

def user_profile_view(request):
  '''Handle the image of the user.'''

  if request.method == 'POST':
      form = UploadPicForm(request.POST, request.FILES)
      if form.is_valid():
        profile = form.save(commit=False)

        # get the base64 image data
        profile.image = request.FILES['imagebase64']
        profile.save()
        messages.success(request, 'your pic updated successfully.')
        return HttpResponseRedirect(reverse('learning_path_tracker:home'))
else:
    # form's user field populated by current user
    form = UploadPicForm(initial={'user': request.user})
return render(request, 'users/uploadpic.html', {'form': form})

Я думаю, что данные изображения не являются строкой, поэтому request.FILES выдает ошибку.Но как я могу решить эту проблему, заранее спасибо.

1 Ответ

0 голосов
/ 01 января 2019

request.FILES содержит только файлы, загруженные с помощью ввода type="file".Принимая во внимание, что вы отправляете данные изображения как base64, используя type="hidden", который отправляет данные в виде строки, а не файла.

Итак, изображение должно присутствовать в request.POST вместо request.FILES.

Сделайте это:

profile.image = request.POST['imagebase64']

В качестве примечания, вместо доступа к ключам непосредственно из словаря, вы должны использовать метод dict get()потому что это позволяет вам указать значение по умолчанию, если запрошенный ключ отсутствует в словаре.

profile.image = request.POST.get('imagebase64', "default value")
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...