Переполнение буфера в C#

418
06 августа 2017, 05:54

Стоит ли переживать насчёт атак "переполнения буфера" в WPF C# и при условии что программа работает на TCP сокетах, то есть активное взаимодействие с сетью, что и опасно?

Я просто знаком с этим видом атаки и знаю, что в основном уязвимы программы, сделанные на чистом C++ или Qt (если конечно, не уделить безопасности должного внимания). Ещё я читал мельком про python, но там (вкратце) говорят, что типа есть своя среда (или оболочка, точно не вспомню), ну и, короче, всё безопасно, а про C# ничего не слышал.

Answer 1

Давайте вспомним, что переполнение буфера — это прежде всего ошибка программиста: он выделяет буфер одного размера, а читает в него данные большего размера. В результате данные затирают область памяти за буфером, то есть, обычно, системный стек.

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

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

READ ALSO
IKernel не могу найти сборку

IKernel не могу найти сборку

Начинаю изучать ASPNET

365
Сокрытие кода с# [дубликат]

Сокрытие кода с# [дубликат]

На данный вопрос уже ответили:

435
c# подставлять элементы массива

c# подставлять элементы массива

Народ подскажите как мне реализовать следующее, есть разрешение в конце имени файла "1024x768", "1280x1024" их всего 4мне нужно чтобы проверялось имя...

357
Зависание серверной программы на C#

Зависание серверной программы на C#

Написал две простые программы: клиент, серверПо нажатию кнопки, в окне программы клиента, клиент отправляет серверу сообщение (кодированное...

339