Заппа, дающая 413 запрос сущности слишком большая ошибка для формы Django с множественными изображениями - PullRequest
0 голосов
/ 17 февраля 2019

У меня есть проект Django, который требует от пользователей добавления нескольких изображений в статью.Я использую django и разворачиваю его с помощью zappa.Я знаю, что в Zappa максимальный размер загрузки страницы составляет 10 МБ.У меня есть 1 сообщение и 7 изображений.Когда пользователь добавляет 7 больших файлов, а затем нажимает «Отправить», я получаю сообщение об ошибке ниже

HTTP413: PAYLOAD TOO LARGE - сервер отказывается обрабатывать запрос, поскольку объект запроса больше, чем желает сервер, илиспособен обрабатывать.

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

class Post(models.Model):
    user = models.ForeignKey(User, related_name='posts')    
    title = models.CharField(max_length=250, unique=True)
    message = models.TextField()
    post_image = models.ImageField(upload_to='post_images/')

    def save(self, *args, **kwargs):
        im = Image.open(self.post_image)
        super(Post, self).save()
        output = BytesIO()
        basewidth = 700
        wpercent = (basewidth / float(im.size[0]))
        hsize = int((float(im.size[1]) * float(wpercent)))
        im = im.resize((basewidth, hsize))
        # after modifications, save it to the output
        im.save(output, format='JPEG', quality=40)
        output.seek(0) 
        self.post_image = InMemoryUploadedFile(output, 'ImageField', "%s.jpg" % self.post_image.name.split('.')[0], 'image/jpeg',
                                          sys.getsizeof(output), None)
        super().save(*args, **kwargs)

Тогда у меня есть модель, которая добавляет несколько сообщений к сообщению

class Prep (models.Model): #(Images)
    post = models.ForeignKey(Post, on_delete=models.CASCADE, related_name='post_prep')
    image = models.ImageField(upload_to='post_prep_images/', blank=True, null=True)
    def save(self, force_insert=False, force_update=False, using=None,
             update_fields=None):
        im = Image.open(self.image)
        output = BytesIO()
        basewidth = 700
        wpercent = (basewidth / float(im.size[0]))
        hsize = int((float(im.size[1]) * float(wpercent)))
        super(Prep, self).save()
        im = im.resize((basewidth, hsize))
        # after modifications, save it to the output
        im.save(output, format='JPEG', quality=300)
        output.seek(0)

        # change the imagefield value to be the newley modifed image value
        self.image = InMemoryUploadedFile(output, 'ImageField', "%s.jpg" % self.image.name.split('.')[0], 'image/jpeg',
                                        sys.getsizeof(output), None)

        super(Prep, self).save()

В моем views.py обе модели объединены для создания 1 формы

@login_required
def post_create(request):
    ImageFormSet = modelformset_factory(Prep, fields=('image', 'image_title', 'image_description'), extra=7, max_num=7,
                                        min_num=2)
    if request.method == "POST":
        form = PostForm(request.POST or None, request.FILES or None)
        formset = ImageFormSet(request.POST or None, request.FILES or None)
        if form.is_valid() and formset.is_valid():
            instance = form.save(commit=False)
            instance.user = request.user
            instance.save()
            post_user = request.user
            for f in formset.cleaned_data:
                try:
                    photo = Prep(post=instance, image=f['image']
                    photo.save()
                except Exception as e:
                    break
            return redirect('posts:single', username=instance.user.username, slug=instance.slug)
    else:
        form = PostForm()
        formset = ImageFormSet(queryset=Prep.objects.none())
    context = {
        'form': form,
        'formset': formset,
    }
    return render(request, 'posts/post_form.html', context)

1 Ответ

0 голосов
/ 18 февраля 2019

10 МБ - это не ограничение Zappa, а ограничение шлюза API .И это, будучи установленным AWS пределом, увеличить его невозможно.

Вы можете пойти по довольно сложному маршруту загрузки больших полезных нагрузок через шлюз API в S3.Подробно об этом рассказывается в этой статье: https://sookocheff.com/post/api/uploading-large-payloads-through-api-gateway/

Или вы можете применить магию внешнего интерфейса и сделать несколько небольших запросов, по одному для каждой загружаемой фотографии.

...