170 похожих чатов

Слушайте, подскажите по REST API. Нужно загружать файлы для какойто-то

сущности. Использовать для этого form-data мне кажется чем-то диким.

Сейчас у меня для этого есть отдельный эндпоинт, куда можно загрузить картинку (просто отправить бинарные данные) и в ответе получить ID загруженной картинки, потом этот ID прикрепить к другой сущности, например это хорошо работает для картинки к новости.

Пример:
- отправляем картинку по пути /api/upload/
- получаем json {"id": 1, "url": "localhost/image.jpg"}
- теперь можем прикрепить такую картинку к новости при создании {"image_id": 1, "title": "Some News"}

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

Но есть несколько неубоств, которых нет, если использовать для таких сущностей form-data:
- картинка и новость это отдельные объекты, из этого вытекает что:
* можно сначала загрузить картинку и не создавать новость, картинка просто останется валяться в ФС беспризорной, прийдется создавать отдельную таску на очистку файлов на которые никто не ссылается
* Если сначала создать новость, а потом прикреплять к ней картинку, то новость может остаться без картинки, а если это обязательное поле?
- если нужно создать файл с какими-то метаданными, то это тоже два запроса - сначала создаем метаданные, потом прикрепляем к ним файл (или наоборот, без разницы) - не очень консистентненько получается.

Кто-то сталкивался с подобными проблемами и как вы их решаете и решаете ли?

5 ответов

5 просмотров

Я в base64 на фронте обычно кодирую, например.

yakimka- Автор вопроса

не нравится, потому что тогда DRF и джанга не смогут без моей помощи валидировать такое поле, да и размер файла, гоняемого по сети таким образом процентов на 30 увеличится

Если у тебя юзер цепляет пикч максимум метров на пять, то увеличение размера в общем-то не критично в большинстве случаев, все ж таки безлимитные интернеты в наше время есть по умолчанию. С валидацией да, сложнее, но выбирая между расширением стандартной валидации и теми проблемами, которые ты довольно подробно описал в изначальном посте - я б укусил пулю и таки написал кастомный валидатор.

yakimka- Автор вопроса

Просто есть сущности к которым могут прикрепить сразу много картинок, размером до 4МБ и мне кажется это довольно критично. В прицнипе с теми проблемами что я описал можно жить, но возможно у кого-то есть мысли как и их обойти

yakimka- Автор вопроса

сама схема мне нравится, она удобна для фронта и для юзера, но вот как-то бы обойти еще эти несколько неудобств и было бы вообще замечательно

Похожие вопросы

Обсуждают сегодня

Anyone here suffers from unexplained aural migraines, who would be up for talking for a bit? Doesn't *have* to be aural, but I am not asking about headaches, I mean actual mi...
Martin Rys
55
подскажите пожалуйста, как мне освободить результат записанный в переменную result? в чем проблема подскажите если МОЖЕТЕ?
Михаил Helper
28
есть тут кто-то , кто только начал изучать си? если проходите курс на степике или как-то сами изучаете, пишите, может, скооперируемся?..
Eule
25
Слушайте, ещё такая интересная задачка. Сделан аудит действий пользователей через триггеры в базе, соответственно каждый пользователь имеет свой логин и пароль в базе. Это пре...
Сергей Бычков
12
Скажите, тут нет проблемы? IMyInterface1 = interface function GetInterface2: IInterface2; ... function TMyInterface.GetInterface2: IInterface2; begin Result := TI...
Ruslan aka DUDE
18
вопрос по москвину - не понимаю вот такого вопроса похоже Сколько разных всегда завершающихся функций с типом a -> a -> b -> a -> a можно реализовать? Две функции одинаково...
Fedor
11
Кстати, раз про скачивание файлов разговор зашел) Сделал бота для себя (транскрибирующего и суммаризирующего встречи) но не ожидал что за 2 месяца 10к пользователей набежит😅...
Andrey Obolenskiy
8
я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
100
Утра доброго. Просветите пожалуйста. Хочу сделать rest сервер на делфи. Посмотрел 3 фреймворка: dmvc, Mars, mormot. Ни в одном из них не упоминается ассинхронная обработка вхо...
Сергей Бычков
10
возможно для форматирования TimeStampZ нужен другой механизм, не?
Роман Лях (rgreat)
13
Карта сайта