Steghide: An introduction
JOLT, a hacking CTF located in Little Rock, Arkansas. JOLT 2022 was where I first was introduced to steghide. Steghide is a tool associated with Steganography which according to wikipedia is: ""the practice of representing information within another message or physical object, in such a manner that the presence of the information is not evident to human inspection". So basically hiding information within a picture. And of course if you can hide information in there you can extract information, and hide information that is dangerous."
On the kali linux steghide page it says: "Steghide is steganography program which hides bits of a data file in some of the least significant bits of another file in such a way that the existence of the data file is not visible and cannot be proven.
Steghide is designed to be portable and configurable and features hiding data in bmp, jpeg, wav and au files, blowfish encryption, MD5 hashing of passphrases to blowfish keys, and pseudo-random distribution of hidden bits in the container data.
Steghide is useful in digital forensics investigations."
You can include passphrases for your files, and do a lot more. Steghide is a really useful tool for gathering information from pictures that have been embedded with steghide.
I am going to demonstrate this by taking a picture and embedding information in it, giving it a passphrase, and then basically reversing that and seeing if we can get the information we put in using stegseek. I encourage you to follow along! :)
Let's begin!
First, we need to install steghide. You can do this on kali by running the
"sudo apt-get install steghide" command.
After that let's pick a photo to select for our example. I love cute kittens so let's find a photo of a cute kitten. :)
"steghide info cute-kitten.jpg" to get some info.
I created a txt file called "cute-kitten.txt" with the word "meow" in it. Now that we have done that we can embed this file into our jpeg with the command "steghide --embed -cf cute-kitten.jpg -ef cute-kitten.txt". This will require you to enter a passphrase, you don't have to, but I encourage you to do so. If you don't anyone will be able to view the contents and that defeats the purpose of steghide, and for this example we will use a passphrase. My super secret passphrase is meow! Once we enter our passphrase twice it now works!
So what happens if we try to get some info on this picture with steghide? Well, when we run "steghide --extract -sf cute-kitten.jpg" we get hit with a passphrase. What happens if we enter it wrong? We get a message telling us we couldn't extract any data.
It's used specifically for steghide cracking!
(Note: You might have heard about or used stegcracker. Last time I used stegcracker it did not work very well, and a previous article I mention that others using it on a ctf challenge I developed had trouble. I recommend replacing it with stegseek, and using stegcracker will give you a similar message to use stegseek!)
Remember our password is "meow"! Let's see if we can get it with rockyou.txt
"stegseek --crack -sf cute-kitten.jpg -xf -wl /usr/share/wordlists/rockyou.txt output2.txt" using that command it takes.... literal seconds! One of the results is "Found passphrase: "meow"
So let's enter that passphrase now with steghide.
"steghide --extract -sf cute-kitten.jpg"
When we enter meow we can option to over-write the data to cute-kitten.txt. This doesn't matter that match for our demonstration.
And there we go!
That's a small and simple example of how to use steghide. It's a great tool to use at CTF's as either a steganography challenge, or to use it for cracking a steghide challenge!
Thanks for taking the time to read and I hope you have a great week! Don't forget to hack the planet!!
-BlackCatt
Comments
Post a Comment