Supply Chain Security
Узнать большеПроверка безопасности приложений: зачем это бизнесу и как ее организовать
Любая технология, которая применяется при разработке программного обеспечения, имеет свойства, выгодные не только для пользователей, но и для злоумышленников. Последних, конечно же, намного меньше, но они существуют. Эти свойства могут влиять на безопасность приложений, наличие в них уязвимостей. Чтобы минимизировать количество уязвимостей, требуется проверка безопасности приложений. Проводится она не только в процессе разработки или после ее завершения. Этот процесс должен быть постоянным.
За 2020 г. в ПО от разных разработчиков было выявлено больше уязвимостей, чем в любой другой год. Общее число официально зарегистрированных дыр, эксплойтов, а также других угроз составило 17550. А ведь есть еще незарегистрированные. Опять же, статистика говорит, что около 90% инцидентов в сфере информационной безопасности происходит из-за использования злоумышленниками известных уязвимостей.
Прикладное программное обеспечение не стоит на месте. Для приложений регулярно выпускаются обновления, появляются дополнительные функции, модули. А вместе с ними могут возникать новые уязвимости. Поэтому компании важно обеспечить контроль, организовать эффективную систему регулярной проверки защищенности программного обеспечения.
Технологии проведения тестирования защищенности приложений. Какую выбрать бизнесу
Для проверки защищенности программного обеспечения принято использовать технологии DAST, SAST, IAST, RASP и другие.
DAST
DAST (от англ. Dynamic Application Security Testing) это динамическое тестирование. Его еще называют тестированием методом черного ящика. Используется для обнаружения уязвимостей в работающих приложениях.
Чтобы протестировать ПО с помощью технологии DAST, его нужно запустить. Работающая программа тестируется в боевой обстановке путем передачи в нее вредоносных данных, внедрения ошибок и с использованием других стрессовых инструментов. Отсюда вытекают сложности, из-за которых технология подходит не каждой компании. Для такого тестирования нужно обеспечить выполнение программы, лучше ее отдельного экземпляра именно для теста. А это дополнительные вычислительные мощности, которые могут быть не у каждого. Кроме того, требуется тщательно продумать вероятные сценарии, реализовать их в ходе тестирования. На такое тестирование иногда требуется немало времени.
Тем не менее DAST достаточно распространенная технология. Если у компании есть соответствующие IT-ресурсы и разработчики в штате, почему бы и не воспользоваться ею? На рынке представлены автоматизированные средства для организации подобных тестов.
SAST-тестирование уязвимости приложений
SAST (Static Application Security Testing) статический метод проверки. Его еще называют методом белого ящика. Более популярен, чем предыдущий: согласно опросам специалистов почти 69% компаний в первую очередь обращают внимание именно на него.
Чтобы проверить безопасность программного обеспечения с помощью технологии SAST, его не требуется запускать. Проверка сводится к анализу кода приложений, возможных уязвимостей, слабых мест. За счет этого реализовать тесты проще, тратится меньше ресурсов и времени.
Из сложностей, с которыми можно столкнуться при выборе этого варианта, большое количество ложных сигналов тревоги, которые придется обрабатывать вручную. На это уходит немало времени. Но здесь многое зависит от SAST-инструмента, который используется при проведении тестов. При разработке Solar appScreener мы уделяем этому вопросу особое внимание. Применяем решения, минимизирующие необоснованные ложные срабатывания, ускоряющие процессы обработки оповещений.
Проверка уязвимости приложений с помощью статической технологии SAST это:
- Универсальность. Одним инструментом можно тестировать разные приложения за счет покрытия множества языков программирования.
- Покрытие всего кода, а не только исполняемого, как при использовании DAST.
- Возможность проверки кода на соответствие руководствам и стандартам кодирования.
- Возможность реализации проверки без высококвалифицированных разработчиков в штате. Проверять ПО с помощью SAST-инструментов могут специалисты по информационной безопасности.
IAST
IAST (Interactive Application Security Testing) это интерактивное тестирование безопасности приложений (программного обеспечения). Технологии присущи черты SAST и DAST. Методика создавалась, чтобы устранить недостатки белого и черного ящиков. Она подразумевает выполнение проверок в режиме реального времени: анализируется код работающего приложения и одновременно с этим моделируются разные ситуации (внедрение ошибок, передача вредоносного кода и так далее, как при DAST).
Такой подход позволяет получать более точные результаты, покрывать больше кода, проверять широкий спектр правил безопасности. Но реализовать его под силу далеко не каждому бизнесу. Автоматизированных инструментов, позволяющих обеспечить проверку по IAST-методологии на рынке практически нет. Для этого нужно использовать DAST и SAST-инструменты в комплексе. Если у компании нет собственной команды разработчиков и соответствующей IT-инфраструктуры, реализовать все сложно.
Доступной большинству остается SAST универсальная методика тестирования приложений на безопасность, которую может использовать практически любая компания. Внедрить инструменты, реализующие ее, относительно просто. Не нужно кардинально менять и дорабатывать существующую IT-инфраструктуру. Процессы в SAST-инструментах максимально автоматизированы. Результаты представляются в наглядном, удобном для восприятия и анализа виде. Технология подходит для поиска уязвимостей в различных приложениях: одним инструментом можно покрыть всю инфраструктуру компании и используемое для работы ПО.