АК-ВС 3 | Анализатор кода
Відкрити в Telegram
Канал для разработчиков, ИБ-специалистов и интеграторов. Здесь рассказываем о безопасности кода, требованиях регуляторов и о том, как работает АК-ВС 3. ИБ новости: https://t.me/EchelonEyes 📞 8 (495) 223-23-92 📩 akvs3@npo-echelon.ru
Показати більшеКраїна не вказанаКатегорія не вказана
233
Підписники
Немає даних24 години
+17 днів
-330 день
Триває завантаження даних...
Схожі канали
Немає даних
Виникли проблеми? Будь ласка, оновіть сторінку або зверніться до нашого support-менеджера.
Хмара тегів
Немає даних
Виникли проблеми? Будь ласка, оновіть сторінку або зверніться до нашого support-менеджера.
Вхідні та вихідні згадування
---
---
---
---
---
---
Залучення підписників
червень '26
червень '26
+1
в 0 каналах
травень '26
+4
в 1 каналах
Get PRO
квітень '26
+9
в 2 каналах
Get PRO
березень '26
+98
в 2 каналах
Get PRO
лютий '260
в 1 каналах
Get PRO
січень '26
+128
в 0 каналах
Get PRO
грудень '250
в 1 каналах
Get PRO
листопад '25
+19
в 1 каналах
| Дата | Залучення підписників | Згадування | Канали | |
| 30 червня | 0 | |||
| 29 червня | 0 | |||
| 28 червня | 0 | |||
| 27 червня | 0 | |||
| 26 червня | 0 | |||
| 25 червня | 0 | |||
| 24 червня | 0 | |||
| 23 червня | +1 | |||
| 22 червня | 0 | |||
| 21 червня | 0 | |||
| 20 червня | 0 | |||
| 19 червня | 0 | |||
| 18 червня | 0 | |||
| 17 червня | 0 | |||
| 16 червня | 0 | |||
| 15 червня | 0 | |||
| 14 червня | 0 | |||
| 13 червня | 0 | |||
| 12 червня | 0 | |||
| 11 червня | 0 | |||
| 10 червня | 0 | |||
| 09 червня | 0 | |||
| 08 червня | 0 | |||
| 07 червня | 0 | |||
| 06 червня | 0 | |||
| 05 червня | 0 | |||
| 04 червня | 0 | |||
| 03 червня | 0 | |||
| 02 червня | 0 | |||
| 01 червня | 0 |
Дописи каналу
➡️Исправление требует проверки
Нашли уязвимость, внесли правку, закрыли задачу. На этом как будто можно поставить точку.
Но на практике такой подход часто оказывается слишком поверхностным.
Исправление само по себе еще не гарантирует, что уязвимость действительно устранена. Поэтому после изменения кода важно провести повторные проверки.
Причин для этого несколько.
✔️Исправление не всегда решает проблему полностью.
Иногда уязвимость закрывают точечно, но не проверяют, используется ли тот же небезопасный подход в других частях проекта.
А иногда после изменения кода появляются новые уязвимости, например, в проверке прав, обработке ошибок или бизнес-логике приложения.
Поэтому повторная проверка после исправления нужна не только для формальности.
Она отвечает сразу на несколько важных вопросов.
〰️Уязвимость точно устранена?
〰️Исправление не привело к новым дефектам?
〰️Продукт после изменений работает так, как должен?
👍Именно поэтому в зрелой разработке ценится не только факт исправления, но и подтверждение его результата.
😎Исправить - это только половина работы.
Вторая половина - убедиться, что исправлено действительно то, что нужно, и так, как нужно.
| 2 | Немає тексту... | 94 |
| 3 | ➡️Чем позже найдена уязвимость, тем выше цена | 126 |
| 4 | Немає тексту... | 166 |
| 5 | Почему JavaScript называется JavaScript
Из-за названия легко подумать, что JavaScript тесно связан с Java.
🤯Но это имя появилось не из-за технического сходства, а во многом из-за популярности бренда Java в середине 90-х.
Язык появился в 1995 году в компании Netscape, которая разрабатывала браузер Netscape Navigator - один из самых известных браузеров того времени.
Его создавали для сценариев внутри веб-страниц, чтобы страницы в браузере могли реагировать на действия пользователя.
Сначала язык назывался Mocha, потом LiveScript, и только затем стал JavaScript.
📝Почему его переименовали именно так?
Потому что в тот момент Java быстро набирала популярность, и имя Java уже хорошо привлекало внимание.
Для нового языка это было удобное название с точки зрения продвижения.
Название JavaScript появилось не случайно. Компания Sun, которой принадлежало имя Java, разрешила Netscape использовать его для нового языка.
🔥Получается интересная ситуация.
Язык получил имя, которое помогло ему быстро стать заметным, но заодно запутало много людей.
😎Пожалуй, это один из самых удачных маркетинговых ходов в истории IT.
И один из самых запутывающих тоже. | 163 |
| 6 | Немає тексту... | 139 |
| 7 | ➡️Имя файла — это тоже часть безопасности | 190 |
| 8 | Немає тексту... | 181 |
| 9 | ➡️Приведение типов и ошибки в логике
После приведения типа значение может измениться не так, как ожидает разработчик. В результате проверка в коде начинает работать неправильно.
🧷 Например:
int x = -1;
unsigned int y = x;
if (y > 0) {
printf("positive\n");
}
📝 Что здесь произошло?
x содержит -1. При приведении к беззнаковому типу (unsigned int) это значение преобразуется так, что то же двоичное представление начинает соответствовать большому положительному числу.
В итоге условие y > 0 окажется истинным, хотя исходное значение было отрицательным.
🔺Чем это опасно:
1. проверка начинает давать неверный результат
2. код заходит не в ту ветку
Из-за этого можно пропустить ошибку или неправильно обработать данные
Чаще всего такие проблемы возникают при работе:
〰️со знаковыми и беззнаковыми типами
〰️с целыми и вещественными числами
〰️с типами разного размера
✔️Как этого избежать:
〰️не приводить тип без необходимости
〰️перед приведением проверять, входит ли значение в целевой диапазон, особенно для отрицательных, больших и граничных значений
〰️включать предупреждения компилятора, связанные с приведением типов
😎Приведение типа может изменить значение сильнее, чем кажется на первый взгляд. | 166 |
| 10 | Немає тексту... | 172 |
| 11 | ➡️Почему ограничения на клиенте не считаются полноценной защитой?
Может показаться, что если нужная проверка уже есть на клиенте, то этого достаточно.
Например:
〰️нельзя ввести больше 20 символов
〰️нельзя загрузить файл больше 5 МБ
〰️нельзя выбрать произвольное значение параметра
〰️кнопка опасного действия скрыта или недоступна
🔺Но клиентская часть приложения находится под контролем пользователя, поэтому полагаться только на проверки на этой стороне нельзя.
Такие ограничения можно обойти:
〰️прямой отправкой запроса в обход интерфейса
〰️отключением или изменением клиентской логики проверки
〰️использованием инструментов вроде curl или Burp Suite
Поэтому проверки на клиенте полезны для удобства и помогают избежать случайных ошибок, но не должны быть единственным механизмом защиты.
Если проверка выполняется только на клиенте, на сервер всё равно могут попасть некорректные, недопустимые или вовсе опасные данные.
На практике действует простое правило:
〰️на клиенте проверки делают для удобства
〰️на сервере проверки делают для безопасности
✔️Вывод
Ограничения на клиенте - это не полноценная защита, а лишь вспомогательная проверка.
Всё, что важно для безопасности, должно проверяться на сервере. | 205 |
| 12 | Немає тексту... | 187 |
| 13 | Почему случайное число не меняется? | 218 |
| 14 | Немає тексту... | 187 |
| 15 | ➡️IDOR - чужие данные по ID
Иногда доступ к объекту зависит от одного идентификатора.
Например, есть ссылка /order/1642 по которой пользователь открывает свой заказ.
Потом он меняет 1642 на 1643 и вдруг видит уже чужой.
🔺Проблема в том, что идентификатор оказался слишком предсказуемым, а проверка доступа недостаточной или вовсе отсутствующей.
Предсказуемые идентификаторы упрощают перебор и открывают доступ к чужим данным.
Чаще всего так получают доступ к:
〰️профилям пользователей
〰️заказам
〰️документам
〰️счетам
〰️заявкам
Но здесь есть важный момент. Даже если вместо 1642 использовать более сложный и менее очевидный идентификатор, проблема не исчезает.
✔️Безопасность здесь зависит не от того, насколько сложно угадать идентификатор, а в первую очередь от проверки прав доступа к объекту.
Если сервер смотрит только на то, существует ли объект, но не проверяет, кто именно запрашивает доступ, этого уже достаточно для инцидента.
Поэтому, если система принимает идентификаторы объектов из запроса, стоит проверить:
〰️можно ли перебирать идентификаторы объектов
〰️есть ли для каждого запроса проверка доступа к нужному объекту
😎Иногда хорошая проверка начинается с простого вопроса: "Что произойдет, если просто поменять ID в запросе?" | 175 |
| 16 | Немає тексту... | 189 |
| 17 | ➡️Утечка через сравнение строк
Как думаете, сколько времени занимает такая проверка?
if token == "secret_key":
allow_access()
Почти за мгновение. Но иногда эти миллисекунды могут выдать секрет.
🔍В чем дело
Во многих реализациях строки сравниваются посимвольно.
Алгоритм обычно выглядит так:
1) Сравнить первый символ
2) Если совпал - второй
3) Если совпал второй - третий
И так далее
Если символ не совпал, тогда сравнение заканчивается.
📝Где появляется проблема
Предположим секретный токен
A9F4K2
Если атакующий отправит
BXXXX
Сравнение закончится на первом символе.
Если отправить AXXXX, то проверка пройдет чуть дальше.
В результате время выполнения будет немного отличаться.
Если отправить много запросов и измерять время ответа, можно постепенно угадывать символы по одному.
✔️Как решают проблему
Используют сравнение за константное время.
Алгоритм сравнивает все символы, даже если первый уже не совпал.
Для этого во многих языках есть специальные функции, например:
GO
subtle.ConstantTimeCompare(a, b)
JavaScript
crypto.timingSafeEqual(a, b)
😎Как часто вы видели проверки секретов через обычное ==? | 818 |
| 18 | Немає тексту... | 171 |
| 19 | 📌Некоторые вещи про безопасность были сказаны задолго до SSDLC | 0 |
| 20 | Немає тексту... | 0 |
Вже доступно! Дослідження Telegram за 2025 — головні інсайти року 
