Interested Article - Стеганография в цифровых изображениях
- 2021-05-05
- 1
Стеганография в цифровых изображениях — раздел стеганографии , изучающий проблему сокрытия данных в цифровых изображениях. В отличие от криптографии , задача стеганографии — скрыть сам факт наличия скрытого сообщения. Основные методы сокрытия информации в цифровых изображениях можно разделить на пространственные и частотные .
Задача стеганографии в изображениях — встроить информацию в цифровое изображение так, чтобы и сообщение, и сам факт его наличия были скрыты . Полученное изображение с дополнительной скрытой информацией не должно выглядеть аномальным. Это достигается путём внесения изменений, незаметных для человеческого зрения . Многие методы стеганографии используют методики, схожие с методами сжатия изображений .
Цифровые изображения представляют особый интерес в качестве контейнеров для скрытых сообщений, поскольку они имеют большой объём и не вызывают подозрений при публикации в социальных сетях и пересылке по электронной почте . В JPEG изображение размером в 733 килобайта поместились все 272 страницы пьесы Шекспира « Макбет » .
Практическое применение
На практике методы стеганографии применяются для идентификации, защиты авторских прав и сокрытия передаваемых сообщений .
Хранение изображений в цифровом формате упрощает их хранение и распространение, но так же увеличивает риск нарушения авторских прав, несанкционированного изменения и распространения. В целях защиты интеллектуальной собственности и определения изменений, разрабатываются и применяются цифровые водяные знаки . К таким стеганографическим методикам предъявляются особые требования:
- Качество исходного изображения не должно быть серьёзно затронуто, скрытые данные должны быть минимально заметны.
- Скрытые данные должны сохраняться в разных форматах , то есть содержаться не только в заголовке, а во всем теле изображения.
- Скрытые данные должны быть устойчивы к намеренным попыткам удаления.
- Необходимо наличие избыточного кода для коррекции ошибок, так как деградация данных при передаче/модификации неизбежна .
В 2018 году сотрудник General Electric использовал фотографию заката чтобы украсть 40 файлов Excel и Matlab , содержащих данные, являющиеся коммерческой тайной .
Facebook манипулирует метаданными изображений, публикуемых на сайте, для отслеживания их дальнейшего распространения .
Цифровые стего-изображения так же встречаются в известной интернет-головоломке Цикада 3301 , одним из основных фокусов которой является стегоанализ .
Пространственные методы
Пространственные методы манипулируют значениями в пространственной области ( пикселями ).
LSB ( англ. Least Significant Bit — Наименее значимый бит )
Данный метод заключается в выделении наименее значимых бит изображения-контейнера с последующей их заменой на биты сообщения. Поскольку замене подвергаются лишь наименее значимые биты, разница между исходным изображением-контейнером и контейнером, содержащим скрытые данные невелика и обычно незаметна для человеческого глаза . Метод LSB применим лишь к изображениям в форматах без сжатия (например, BMP ) или со сжатием без потерь (например, GIF ), так как для хранения скрытого сообщения используются наименее значимые биты значений пикселей, при сжатии с потерями эта информация может быть утеряна. Форматы без сжатия имеют очень большой размер и могут вызвать подозрение, поэтому для стеганографии чаще используют другие форматы .
Встраивание
Например, имеется чёрно-белое изображение, представленное в виде матрицы . Значения в этой матрице соответствуют яркостям пикселей, расположенных по координатам . Пусть эти значения представлены восьмибитными двоичными числами. Пусть скрываемое сообщение имеет размер 2 байта . Для хранения скрытого сообщения возьмём 2 младших бита изображения-контейнера. Тогда для сокрытия 2 байт, то есть 16 бит необходимо изображение размером минимум 8 пикселей. Если изображение содержит больше пикселей, чем необходимо для хранения сообщения, необходимо выбрать правило, по которому будут выбираться пиксели для встраивания данных. Этот закон должен быть заранее известен получателю, так как он будет необходим для извлечения данных. Для сокрытия факта встраивания данных, к неиспользованным пикселям изображения добавляется шум , чтобы шум, вносимый скрытыми данными, не выглядел аномальным. Например, имея изображение размером 4x2 пикселя запишем первые два бита сообщения 0001101100011011 в первый пиксель: пусть исходное значение пикселя 10100101, заменим младшие два бита на первые два бита сообщения 101001 00 . Следующие два бита записываются в следующий пиксель, и так далее .
Извлечение
Для извлечения скрытых методом LSB данных, необходимо выбрать пиксели, содержащие полезную нагрузку по тому же закону, по которому они выбирались при встраивании. Далее, имея набор пар координат вида , по очереди, извлекаются наименее значимые биты: 101001 00 . Извлечённые биты данных объединяются, формируя скрытое сообщение .
PVD ( англ. Pixel Value Difference — Разность значений пикселей)
Этот метод учитывает тот факт, что на гладких участках (где значение яркости меняется незначительно) изменение будет более заметно, нежели на участках, содержащих более значительные перепады яркости .
Встраивание
Исходное изображение разделяется на блоки по 2 пикселя, и скрытые данные кодируются как разность значений внутри этих блоков. Как и в случае с LSB, необходим закон, по которому будут выбираться блоки для встраивания. Для каждого используемого блока вычисляется модуль разности значений пикселей, по которому определяется диапазон допустимых значений. Чем больше перепад яркости внутри блока- тем шире выбранный диапазон . Для удобства работы, ширина диапазона является степенью двух. Тогда, например, в блок с диапазоном шириной 4= можно записать 2 бита скрываемого сообщения (эти два бита, по сути, представляют собой выбор конкретного числа из диапазона). Блоки, изменение которых может привести к выходу за пределы допустимых значений яркости пикселей (от 0 до 255) не используются .
Извлечение
Для извлечения данных, изображение вновь делится на блоки по 2 пикселя. В соответствии с заранее известными правилом выбора блоков и последовательностью их обхода, для блоков рассчитывается разность значений пикселей и определяется диапазон, в который она попадает. Далее выполняется проверка на выход за пределы диапазона от 0 до 255: если при максимальной разности, входящий в диапазон, один из пикселей принимает значение больше 255 или меньше 0, то данный блок пропускается, так как он был отброшен аналогичной проверкой на стадии встраивания. Из оставшихся блоков извлекаются данные: по ширине диапазона определяется количество бит, встроенных в блок, которые потом извлекаются, начиная с наименее значимого. В общем же случае, когда ширина диапазона не является степенью 2, полезная нагрузка вычисляется как , где — извлекаемые данные, - значения пикселей блока, - нижняя граница диапазона .
GLM ( англ. Grey Level Modification — Изменение уровня серого)
Метод GLM заключается в изменении чётности значения яркости изображения в чёрно-белом представлении. В каждый пиксель изображения встраивается 1 бит скрываемого сообщения.
Встраивание
В начале значения яркости всех пикселей делаются чётными, путём изменения всех нечётных значений на 1. Далее чётность этих значений сравнивается с чётностью битов данных. Например, если первый бит данных чётный (то есть равен 0), то первый пиксель не изменяется, если же он нечётный (равен 1), то значение яркости изменяется на нечётное .
Извлечение
Для каждого пикселя, содержащего скрытое сообщение, определяется значение яркости. Если оно чётное- то соответствующий бит сообщения равен 0, если нечётное — то 1 .
MPV ( англ. Mid Position Value — Значение в средней позиции)
В данном методе к изображению-контейнеру сначала применяется , затем для каждого пикселя вычисляется его позиция . Для каждого оценивается количество знаков и положение среднего знака . Далее берётся число из позиции в и вычисляется ключ . Если это число превышает количество пикселей изображения, то берётся его остаток от деления на количество пикселей . Далее берётся десятичное значение последних 4 бит пикселя номер и вычисляется . В -й пиксель встраивается 2 бита данных по правилу: если -чётное, то применяется прямое встраивание, если нечётное- то обратное. Если - чётное то встраиваются два бита сообщения, нечётное- встраиваются комплементарные 2 бита. К полученному изображению применяется обратное преобразование Арнольда .
Частотные методы
Частотные методы работают с коэффициентами в частотной области.
DCT ( англ. Discrete Cosine Transform — Дискретное косинусное преобразование )
Данный метод использует DCT-преобразование для перехода в частотную область и представляет собой LSB в применении к коэффициентам DCT. Поскольку сжатие JPEG так же использует DCT преобразование, то данную методику возможно применить к сжатым JPEG-изображениям. При использовании формата JPEG, встраивание производится после сжатия с потерями, использующего DCT, но до применения кода Хаффмана для дальнейшего сжатия коэффициентов DCT без потерь .
Встраивание
Исходное изображение-контейнер разделяется на блоки по 8x8 пикселей, к которым применяется DCT: . Из каждого коэффициента матрицы выделяются наименее значимые биты и заменяются на биты скрываемого сообщения .
Извлечение
Изображение-контейнер разделяется на блоки по 8x8 пикселей, к которым применяется DCT: . Из каждого коэффициента матрицы выделяются наименее значимые биты и объединяются, восстанавливая скрытое сообщение .
DWT ( англ. Discrete Wavelet Transform — Дискретное вейвлет-преобразование )
По своей сути данная методика схожа с основанной на DCT, но вместо DCT-преобразования для перехода в частотную область используется DWT-преобразование . Один из предложенных методов, основанных на DWT-преобразовании предполагает определение областей изображения, содержащих цвет человеческой кожи в пространстве HSV , затем применяется DWT-преобразование и данные встраиваются только в эти области .
Примечания
- ↑ Bhallamudi, Savitha. , (2015).
- ↑ Сейеди С. А., Садыхов Р. Х. от 19 декабря 2019 на Wayback Machine . Информатика . 2013;(1):66-75.
- (англ.) . Computer Business Review (20 июня 2019). Дата обращения: 18 декабря 2019. 18 декабря 2019 года.
- ↑ Alaa A. Jabbar Altaay, Shahrin bin Sahib, Mazdak Zamani. (англ.) // International Conference on Advanced Computer Science Applications and Technologies, At Kuala Lumpur, Malaysia. — 2012. — Vol. ACSAT’12 .
- Osama Hosam. (англ.) // International Journal of Information Technology and Computer Science. — 2019.
- Danny Bradbury (2019-04-24). . Infosecurity Magazine . из оригинала 17 декабря 2019 . Дата обращения: 18 декабря 2019 .
- Zak Doffman. (англ.) . Forbes. Дата обращения: 18 декабря 2019. 17 декабря 2019 года.
- ↑ Da-Chun Wu, Wen-Hsiang Tsai. [ A steganographic method for images by pixel-value differencing] (англ.) // Pattern Recognition Letters. — 2003. — No. 24 . 9 августа 2017 года.
- ↑ V.M. Potdar, E. Chang. (англ.) // IEEE International Conference on Industrial Informatics. — 2004. — No. 2 .
- Srilekha Mukherjee, Subhajit Roy, Goutam Sanyal. (англ.) // Procedia Computer Science. — 2018. — Vol. 132 . 17 декабря 2019 года.
- Falesh M. Shelke, Ashwini A. Dongre, Pravin D. Soni. [ Comparison of different techniques for Steganography in images] (англ.) // International Journal of Application or Innovation in Engineering & Management. — 2014. — February ( vol. 3 , no. 2 ). — ISSN . 25 декабря 2019 года.
- ↑ Monika Gunjal, Jasmine Jha. // International Journal of Computer Trends and Technology. — 2014-05-25. — Т. 11 , вып. 4 . — С. 144—150 . — ISSN . — doi : .
- Swapnali Zagade, Smita Bhosale. [ Secret Data Hiding in Images by using DWT Technique’s] (англ.) // International Journal of Engineering and Advanced Technology (IJEAT). — 2014. — Vol. 3 , no. 5 . — ISSN . 17 декабря 2019 года.
- 2021-05-05
- 1