News Grower

Независимое покрытие AI, стартапов и технологий.

Habr 26.03.2026 07:28 Developer Tools

Безопасный file upload в Go: 7 атак на загрузку файлов и как мы их закрывали

«Сделай форму загрузки PDF» – звучит как задача на полчаса. Claude/GPT напишет handler, мы добавим accept=".pdf" на фронте, multer на бэке – и вот у нас работающий upload. Можно деплоить.Проблема в том, что работающий upload и безопасный upload – это разные вещи. Разница между ними – несколько уязвимостей, каждая из...

Безопасный file upload в Go: 7 атак на загрузку файлов и как мы их закрывали

«Сделай форму загрузки PDF» – звучит как задача на полчаса. Claude/GPT напишет handler, мы добавим accept=".pdf" на фронте, multer на бэке – и вот у нас работающий upload. Можно деплоить.Проблема в том, что работающий upload и безопасный upload – это разные вещи. Разница между ними – несколько уязвимостей, каждая из которых может превратить ваш сервер в точку входа для атакующего.С распространением LLM-инструментов порог входа в разработку снизился радикально. Это прекрасно – больше людей могут создавать продукты. Но вместе с порогом входа снизился и порог входа для уязвимостей. Когда LLM генерирует код загрузки файла, она решает функциональную задачу: принять файл, сохранить, обработать. Безопасность? «Добавлю потом». А «потом» обычно наступает после инцидента.Я решил не ждать инцидента и разобрался заранее: какие атаки существуют при загрузке файлов, что бывает, когда про них забывают, и как мы от них защитились в конкретном проекте.

Связанные теги

Компании и люди

Линия сюжета

Продолжить следить за темой

Переходите к связанным материалам, страницам сущностей и активным линиям сюжета.

Что умеют школьники, которые через 5 лет будут нашими коллегами
Habr 26.03.2026 09:23 Developer Tools

Что умеют школьники, которые через 5 лет будут нашими коллегами

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

Habr 26.03.2026 09:16 Developer Tools

Как AI-копилоты изменили мой рабочий процесс во фронтенде — и где с треском провалились

AI-копилот за 40 секунд сгенерировал мне форму на 180 строк с валидацией через zod и сэкономил полчаса. А потом потратил два моих часа на отладку хука с race condition, который ...

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes
Habr 26.03.2026 09:05 Developer Tools

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes

В C++ уже есть корутины. Есть диапазоны. Есть готовые библиотеки.Но это не мешает взять гаечный ключ и начать собирать генератор вручную.В предыдущей статье макросы внезапно нач...

ИИ не понимает код, пока разработчик не понимает его «мышление»
Habr 26.03.2026 09:01 Developer Tools

ИИ не понимает код, пока разработчик не понимает его «мышление»

Разработчики всё чаще подключают ИИ к задачам — от обработки данных до генерации тестов. На первом просмотре такой код выглядит аккуратно и логично. Но&...

Кастомный стратокастер со встроенным перегрузом
Habr 26.03.2026 09:01 Developer Tools

Кастомный стратокастер со встроенным перегрузом

Привет, Хабр! Знакомый электрогитарный энтузиаст попросил помочь доработать его инструмент с оригинальным авторским оформлением. Сейчас мы увидим и услышим, что из этого получил...

Рекламный слот

Article monetization slot

Reserved for contextual monetization inside article pages.

Explore options

Похожие статьи

Еще материалы, которые пересекаются по тегам, источнику или категории.

Что умеют школьники, которые через 5 лет будут нашими коллегами
Habr 26.03.2026 09:23 Developer Tools

Что умеют школьники, которые через 5 лет будут нашими коллегами

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

Habr 26.03.2026 09:16 Developer Tools

Как AI-копилоты изменили мой рабочий процесс во фронтенде — и где с треском провалились

AI-копилот за 40 секунд сгенерировал мне форму на 180 строк с валидацией через zod и сэкономил полчаса. А потом потратил два моих часа на отладку хука с race condition, который ...

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes
Habr 26.03.2026 09:05 Developer Tools

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes

В C++ уже есть корутины. Есть диапазоны. Есть готовые библиотеки.Но это не мешает взять гаечный ключ и начать собирать генератор вручную.В предыдущей статье макросы внезапно нач...

Еще материалы от Habr

Свежие публикации и продолжение темы от той же редакции.

Открыть страницу источника
Что умеют школьники, которые через 5 лет будут нашими коллегами
Habr 26.03.2026 09:23 Developer Tools

Что умеют школьники, которые через 5 лет будут нашими коллегами

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

Habr 26.03.2026 09:16 Developer Tools

Как AI-копилоты изменили мой рабочий процесс во фронтенде — и где с треском провалились

AI-копилот за 40 секунд сгенерировал мне форму на 180 строк с валидацией через zod и сэкономил полчаса. А потом потратил два моих часа на отладку хука с race condition, который ...

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes
Habr 26.03.2026 09:05 Developer Tools

Как убрать virtual и не сойти с ума: велосипедные генераторы через type loopholes

В C++ уже есть корутины. Есть диапазоны. Есть готовые библиотеки.Но это не мешает взять гаечный ключ и начать собирать генератор вручную.В предыдущей статье макросы внезапно нач...