Skip to content

bilalcorbacioglu/Steganography

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

15 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Steganografi

Secret-Sharing Secret-Sharing Secret-Sharing

Turkish -> README.md

Steganography, in ancient Greek means "hidden post" and information hiding (important: not encryption) is the name given to the science. The biggest advantage of steganography based on cryptography, in anyone who sees the information, is an important information does not notice what you see. Thus, it does not search for inside information. (However, even though it is difficult to decode an encrypted message, the mystery attracts the interest hence)

In this program, we used the technique of the inversion of the most pointless bits of hidden data. I'll try to explain the logic below.

Process

As you know, the images in pixels, of the pixel consists of RGB values. The basic concept, R G B values are to be stored.

We've got two kind of picture, Hide and carrier image. Hide image, we want to embed into the picture carrier. For example, 1.pixel, let's consider the values of R.

Hide image              Carrier image
R = 41                  R = 12
R = 00101001            R = 00001100

Here is the basic logic, the image to hide the RGB values of binary value. Last 2-3 bits (LSB bits), carrier image pixel corresponding to the value of bit (LSB bits) is to bury. The rest of the next pixel value (LSB). Thus, all pixel values of the image that will be hidden when the carrier is embedded into the image, and the process repeats itself.

So why are we in the last 2 or 3 bits of the holes?

Because the last 4 bits into bury, become aware of the change to the human eye. In fact, the last 3 bits could even be risky. 2-bit exact result. I buried the last 2 bits in this program. Let's continue from the example above.

Hide image              Carrier image
R = 00101001            R = 00001100 (1.Pixel)
                        G = 00010111
                        B = 01001001
                        R = 01011011 (2.Pixel)
                        G = 10100111
                        B = 11100101

After running the program, into the carrier image, the picture to hide 1. Pixel (R value) notice was buried..

Hide image              Carrier image
                            old         new
R = 00101001            R = 00001100 -> 00001100 (1.Pixel)
                        G = 00010111 -> 00010110
                        B = 01001001 -> 01001010
                        R = 01011011 -> 01011001 (2.Pixel)
                        G = 10100111 -> 10100111
                        B = 11100101 -> 11100101
  • Steganography and Secret Sharing is used with the, reverse engineering will be quite difficult.

Dimension

The hidden image size 25 x 30, To completely cover up the image of this size, carrier size is calculated as follows.

0 <= 25 x 30 <= (M X N X S)/8   
  • M X N The size of the image carrier
  • S how many bits to embed (Last bits !)

Run

  • Required Package for Linux
$ sudo apt-get install monodevelop
$ msc Program.cs
$ mono Program.exe

Credits

License

The GNU General Public License - see LICENSE.md

About

Steganography Image to Image, Text to Image

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages