Эта статья является кандидатом в добротные статьи

Безопасное программирование: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[непроверенная версия][непроверенная версия]
Содержимое удалено Содержимое добавлено
Важность: обновление
Принципы: грамматика
Строка 24: Строка 24:


=== Принципы ===
=== Принципы ===
В настоящее время существует огромное число практик написания [[Программное обеспечение|ПО]]. Но есть наиболее важные принципы остающиеся важными при любом подходе{{sfn|Современные технологии разработки надежных и безопасных программ|2008|pp=25-26}}.
В настоящее время существует огромное число практик написания [[Программное обеспечение|ПО]]. Но есть наиболее значимые принципы, учитываемые при любом подходе{{sfn|Современные технологии разработки надежных и безопасных программ|2008|pp=25-26}}.


* Работоспособность и полезность ([[юзабилити]], {{lang-en|usability}})
* Работоспособность и полезность ([[юзабилити]], {{lang-en|usability}})

Версия от 10:52, 12 ноября 2017

Безопасное программирование — это практика разработки программного обеспечения, предотвращающая случайное внедрение уязвимостей и обеспечивающая устойчивость к воздействию вредоносных программ и несанкционированному доступу. Баги и логические ошибки являются основной причиной появления уязвимостей программного обеспечения.

Безопасное программное обеспечение — программное обеспечение, разработанное с использованием совокупности мер. направленных на предотвращение появления и устранение уязви­мостей программы[1].

Задача безопасного программирования — защита персональных данных пользователя от кражи и порчи. Небезопасная программа — потенциальная цель для злоумышленника, который может использовать имеющиеся уязвимости для просмотра, изменения или удаления имеющейся информации, влияния на работу программ и сервисов (запуск или остановка), внедрения вредоносного кода в систему[2].

Терминология

В англоязычной литературе существует два термина, которые могут быть переведены, как безопасное программирование.

Defensive programming (Оборонительное, защитное, безопасное программирование) — это практика разработки ПО, в процессе которой разработчики пытаются учесть все возможные ошибки и сбои, максимально изолировать их и при возможности восстановить работоспособность программы. Это должно делать программное обеспечение более стабильным и менее уязвимым. Например, аппаратной реализацией данного принципа является сторожевой таймер, вычисление контрольной суммы — для выявление ошибок при пакетной передаче данных[3].

Secure coding (Безопасное программирование) — это практика написания программ, устойчивых к атакам со стороны вредоносных программ и злоумышленников. Безопасное программирование помогает защитить данные пользователя от кражи или порчи. Кроме того, небезопасная программа может предоставить злоумышленнику доступ к управлению сервером или компьютером пользователя; последствия могут быть различны: от отказа в обслуживании одному пользователю до компроментации секретной информации, потери обслуживания или повреждения систем тысяч пользователей[2].

Важность

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

Необходимо относиться к безопасности, как к неотъемлемой части общего дизайна системы[англ.][4]. Требования к безопасности конкретных продуктов и систем ИТ устанавливаются исходя из имеющихся и прогнозируемых угроз безопасности, проводимой политики безопасности, а также с учетом условий их применения[5]. Внедрение решений для обеспечения безопасности после того, как система уже разработана, является сложной и дорогостоящей процедурой. Поэтому следует учитывать требования к безопасности на протяжении всего жизненного цикла системы, с самого начала проектирования[4].

Информационная система включает в себя физический и логический уровень. Понимание того, что именно должно быть защищено от внешних факторов, помогает с наиболее эффективным выбором и применением защитных мер. Четкая граница между уровнями должна определяться политикой безопасности, регулирующей определенный набор информации и информационных технологий, имеющий физические границы. Дальнейшее усложнение заключается в том, что на одном компьютере или сервере может размещаться как общедоступная, так и конфиденциальная информация. В результате несколько политик безопасности могут применяться к одной машине или в пределах одной системы. Поэтому при разработке информационной системы границы безопасности должны учитываться и описываться в соответствующей документации и политиках безопасности системы[4].

Стоит учесть, что разработчики должны уметь обеспечивать безопасность при проектировании, разработке, управлении и конфигурировании, интеграции[англ.], правильно проводить тестирование[6].

Анализ (ручной или автоматический) и обеспечение безопасности — дорогостоящая процедура, увеличивающая общую стоимость программного продукта. Ранее полное устранение рисков было общей целью обеспечения безопасности. Сегодня признается, что устранение всех рисков не является экономически эффективным. Для каждой предлагаемой системы контроля следует провести анализ затрат и выгод. В некоторых случаях преимущества более безопасной системы могут не оправдывать прямых и косвенных издержек. Выгоды включают не только предотвращение денежных потерь; стоит учитывать, например, и репутационные потери. Прямые расходы включают расходы на приобретение и установку данной технологии; косвенные расходы включают снижение производительности системы и дополнительное обучение сотрудников[7].

Принципы

В настоящее время существует огромное число практик написания ПО. Но есть наиболее значимые принципы, учитываемые при любом подходе[8].

  • Работоспособность и полезность (юзабилити, англ. usability)
  • Безопасность (англ. security) — возможность защиты от внешних угроз, атак и сохранение работоспособности после их отражение и устранения.
  • Надежность (англ. reliability) — предсказуемое, корректное и безотказное поведение в случае некорректных исходных данных.
  • Конфиденциальность (англ. privacy) — обеспечение безопасной и корректной работы с конфиденциальной информацией.
  • Обеспечение целостности и корректности бизнеса (англ. business integrity) — четкая организация сопровождения программы контроль прозрачности, законности, корректности работы пользователя.

Четыре последних качества стали основой Trustworthy computing (TwC) (англ. Trustworthy computing) («Вычисления заслуживающие доверия») — инициативы корпорации Microsoft, главная задача которой — обратить внимание разработчиков на важность обеспечения указанных требования на каждом из этапов разработки ПО[9].

Существует множество принципов обеспечения безопасности ПО, большей частью похожих друг на друга. Их обобщением можно считать приведенные выше принципы[10].

Классификация и виды уязвимостей

Классификаторы

Для более удобной работы по обеспечению безопасности и устранению проблем с ней уязвимости необходимо классифицировать. В первую очередь подобные классификаторы должны помогать специалистам и экспертам, работающим над устранением уязвимостей. Каждая уязвимость должна быть определённым образом строго задокументирована[11].

  • CVE (Common Vulnerabilities and Exposures) — словарь конкретных уязвимостей конкретных продуктов.
  • CWE (Common Weakness Enumeration) — база данных типов уязвимостей. Основная задача проекта — предоставить описания распространенных видов уязвимостей, способы их предотвращения, обнаружения и исправления.
  • SecurityFocus BID
  • OSVDB (Open Sourced Vulnerability Database) — «открытая база данных уязвимостей», созданная тремя некоммерческими организациями. Прекратила работу 5 апреля 2016 года. Блог продолжает работать[12].
  • Secunia — лента уязвимостей известной датской компании Secunia в области компьютерной и сетевой безопасности.
  • IBM ISS X-Force

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

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

Метрики

Каждая программа является потенциальной целью для злоумышленников. После нахождения уязвимосей в приложениях или серверах они будут пытаться использовать их для кражи конфиденциальной информации, порчи данных, управления компьютерными системами и сетями[13]. Для описания свойств уязвимости специалистами используется система подсчета рисков уязвимостей CVSS?!. Она представляет собой шкалы, на основе которых выставляются баллы. Система метрик придумана для разделения приоритетов над исправлением уязвимостей. Каждая шкала относится к определённому смысловому разделу, который называется метрикой. Таких метрик три[14][15][11]:

  • Базовая (англ. base) — характеристики уязвимости, не зависящие от времени и среды исполнения. Служит для описания сложности эксплуатации уязвимости, потенциального ущерба для конфиденциальности, целостности и доступности информации.
  • Временная (англ. temporal) — метрика, учитывающий временной фактор, например, время на исправление уязвимости.
  • Контекстная (англ. environmental) — метрика, учитывающая информацию о среде функционирования программного обеспечения.

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

Виды уязвимостей

Список наиболее распространенных ошибок, ставящих под угрозу безопасность современных программ[16].

Перечислить все известные уязвимости невозможно, учитывая, что каждый день появляются новые. В данном списке приведены наиболее часто встречающиеся уязвимостей, допустить которые легко, но последствия которых могут быть катастрофическими. Например, причиной распространения червя Blaster стала ошибка всего в двух строках кода[19].

Ущерб

Информация об уязвимостях может быть использована злоумышленниками при написании вирусов. Например, один из первых известных сетевых червей — вирус Морриса в 1988 году использовал такие уязвимости как переполнение буфера в Unix-демоне finger для распространения между машинами. Тогда количество зараженных машин составило порядка 6 тысяч [20], а экономический ущерб по данным счётной палаты США составил от $100,000 до $10,000,000[21].

В 2016 компьютерные вирусы причинили мировой экономике ущерб в 450 миллиардов долларов [22][23].

В 2017 ущерб от вируса WannaCry оценивают в $1 млрд. Случаи заражения были зафиксированы по меньшей мере в 150 странах[24][25][26]. Вирус использовал эксплойт EternalBlue, использующий уязвимость в протоколе SMB, связанную с переполнением буфера[27][28][29][30].

Примечания

  1. ГОСТ Р 56939-2016, 2016, Термины и определения, pp. 2.
  2. 1 2 Introduction to Secure Coding Guide.
  3. Defensive Programming.
  4. 1 2 3 Engineering Principles for Information Technology Security, 2004, Security Foundations.Principle 2, pp. 7.
  5. Критерии оценки безопасности информационных технологий, 2002, Общие положения, pp. III-IV.
  6. Engineering Principles for Information Technology Security, 2004, Security Foundations, pp. 6-8.
  7. Engineering Principles for Information Technology Security, 2004, Security Foundations. Principle 5, pp. 8.
  8. Современные технологии разработки надежных и безопасных программ, 2008, pp. 25-26.
  9. Современные технологии разработки надежных и безопасных программ, 2008, pp. 26.
  10. Secure Programming HOWTO - Creating Secure Software, 2015, Security Principles, pp. 7-8.
  11. 1 2 Журнал Хакер: Меряем уязвимости, 2009, pp. 48—51.
  12. https://blog.osvdb.org/2016/04/05/osvdb-fin/
  13. Introduction to Secure Coding Guide, At a Glance.
  14. Common Vulnerability Scoring System, 2006, p.86.
  15. CVSS:Specification.
  16. 24 Deadly Sins of Software Security: Programming Flaws and How to Fix Them, 2009, Inroduction.
  17. Метод поиска уязвимости форматной строки.
  18. The Protection of Information in Computer Systems, 1975, h) Psychological acceptability: «Очень важно, чтобы пользовательский интерфейс был удобным в использовани, чтобы пользователи интуитивно и просто применяли механизмы защиты правильным образом. Если мысленые представления пользователя о целях защиты соответствуют тем механизмам, которые он использует на практике, количество ошибок будет сведено к минимуму. Если же пользователь должен переводить свои представления о защите на совершенно иной язык специфи­ каций, он неизбежно будет совершать ошибки.».
  19. Secure Coding in C and C++, Figure 1.2. Flawed logic exploited by the W32.Blaster.Worm: «Недостатки логики, использованные червем W32.Blaster.Worm, показаны на рис. 1.2. Ошибка заключается в том, что цикл while в строках 21 и 22 (используемый для выделения имени узла из длинной строки) недостаточно ограничен.».
  20. Записки исследователя компьютерных вирусов, 2005, Таблица 3.1, p. 90.
  21. Апелляционный суд США оценил стоимость удаления вируса с каждой зараженной машины от $200 до $53,000. Вероятно на основании этих данных и был проведён расчёт.
  22. CNBC International: Cybercrime costs the global economy $450 billion.
  23. The New Paper: Cybercrime cost world economy $620 billion last year.
  24. РБК: Ущерб от вируса WannaCry оценили в $1 млрд.
  25. 6abs: The damage from the virus WannaCry exceeded $ 1 billion.
  26. Hi-Tech Mail.ru: Эксперты назвали рекордную сумму ущерба от вируса WannaCry.
  27. MS17-010: EternalBlue’s Large Non-Paged Pool Overflow in SRV Driver.
  28. WannaCry ransomware used in widespread attacks all over the world.
  29. CNews: Экономический ущерб от вирусов.
  30. Net Losses: Estimating the Global Cost of Cybercrime.

Литература

  • Howard M., LeBlanc D., Viega J. 24 Deadly Sins of Software Security: Programming Flaws and How to Fix Them (англ.). — McGraw Hill Professional, 2009. — 464 p. — ISBN 9780071626767.
  • M. Tim Jones. Defensive Programming (англ.) (1 февраля 2005). Дата обращения: 12 ноября 2017.

Дополнительная литература