In general decompilers are not friendly with c++ let's analyse a simple program to get familiar with it.
Let's implement a simple code that loads a file into a vector and then save the vector with following functions:
Lets identify the typical way in C++ to print to stdout with the operator "<<"
The basic_ostream is initialized writing the word "error" to the cout, and then the operator<< again to add the endl.
The Main function simply calls "vec = load(filename)" but the compiler modified it and passed the vector pointer as a parámeter. Then it bulds and prints "loaded " << size << " users".
And finally saves the vector to /tmp/pwd and print "saved".
Most of the mess is basically the operator "<<" to concat and print values.
Also note that the vectors and strings are automatically deallocated when exit the function.
And here is the code:
Let's take a look to the load function, which iterates the ifs.getline() and push to the vector.
First of all there is a mess on the function definition, __return_storage_ptr is the vector.
the ifstream object ifs is initialized as a basic_ifstream and then operator! checks if it wasn't possible to open the file and in that case calls err()
We see the memset and a loop, getline read a cstr like line from the file, and then is converted to a string before pushing it to the vector. lVar1 is the stack canary value.
In this situations dont obfuscate with the vector pointer vec initialization at the begining, in this case the logic is quite clear.
The function save is a bit more tricky, but it's no more than a vector iteration and ofs writing.
Looping a simple "for (auto s : *vec)" in the decompiler is quite dense, but we can see clearly two write, the second write DAT_0010400b is a "\n"
As we see, save implememtation is quite straightforward.
Let's implement a simple code that loads a file into a vector and then save the vector with following functions:
- err
- load
- save
- main
Lets identify the typical way in C++ to print to stdout with the operator "<<"
The basic_ostream is initialized writing the word "error" to the cout, and then the operator<< again to add the endl.
The Main function simply calls "vec = load(filename)" but the compiler modified it and passed the vector pointer as a parámeter. Then it bulds and prints "loaded " << size << " users".
And finally saves the vector to /tmp/pwd and print "saved".
Most of the mess is basically the operator "<<" to concat and print values.
Also note that the vectors and strings are automatically deallocated when exit the function.
And here is the code:
Let's take a look to the load function, which iterates the ifs.getline() and push to the vector.
First of all there is a mess on the function definition, __return_storage_ptr is the vector.
the ifstream object ifs is initialized as a basic_ifstream and then operator! checks if it wasn't possible to open the file and in that case calls err()
We see the memset and a loop, getline read a cstr like line from the file, and then is converted to a string before pushing it to the vector. lVar1 is the stack canary value.
The function save is a bit more tricky, but it's no more than a vector iteration and ofs writing.
Looping a simple "for (auto s : *vec)" in the decompiler is quite dense, but we can see clearly two write, the second write DAT_0010400b is a "\n"
More articles
- Wifi Hacker Tools For Windows
- Hacking Tools Windows 10
- Underground Hacker Sites
- Hack Tools For Games
- Hacker Tools Software
- Hacks And Tools
- Hack App
- Tools For Hacker
- Blackhat Hacker Tools
- World No 1 Hacker Software
- Hacker Hardware Tools
- Hack Rom Tools
- Usb Pentest Tools
- Physical Pentest Tools
- Hacking Tools Software
- Hacking Tools Kit
- Hacker Tools Mac
- Computer Hacker
- Pentest Reporting Tools
- Pentest Tools For Ubuntu
- Hacker Tools Free
- Hack Tools Download
- Hacking Tools Windows
- Hack Tools For Ubuntu
- Hack Tools Online
- Pentest Tools Website Vulnerability
- Wifi Hacker Tools For Windows
- Pentest Tools For Ubuntu
- Hacks And Tools
- Hacker Tools Online
- Hacking Tools For Mac
- Hacking Tools Windows 10
- Nsa Hack Tools
- Pentest Tools Website Vulnerability
- Hacking Tools 2019
- Hacker Tools Apk
- Hacker Tools List
- Hacker Tools Apk
- Pentest Tools Subdomain
- How To Install Pentest Tools In Ubuntu
- Hacking Tools For Games
- Hacker Tools For Mac
- Pentest Tools Free
- Hacker Tools Github
- Pentest Tools Windows
- Bluetooth Hacking Tools Kali
- Pentest Tools Website Vulnerability
- New Hacker Tools
- Hacking Tools And Software
- Hacking Tools For Mac
- Hacker Techniques Tools And Incident Handling
- Best Pentesting Tools 2018
- What Are Hacking Tools
- Hacker Tools For Ios
- Tools For Hacker
- Hacking Tools For Beginners
- Hacker Tools Linux
- Hacking Tools
- Hack Tool Apk
- Hacking Tools Hardware
- Hak5 Tools
- Free Pentest Tools For Windows
- Game Hacking
- Hacking Tools For Windows Free Download
- Hack Tool Apk
- Bluetooth Hacking Tools Kali
- Hack Apps
- Blackhat Hacker Tools
- Hacking Tools And Software
- Pentest Tools Find Subdomains
- Hacker Tools Free
- Hak5 Tools
- Easy Hack Tools
- Pentest Tools For Ubuntu
- Hacking Tools Online
- Pentest Box Tools Download
- Pentest Tools Website Vulnerability
- Kik Hack Tools
- Hack Tools For Pc
- Free Pentest Tools For Windows
- Hack Tools Download
- Hacker Tools For Pc
- How To Make Hacking Tools
- Hacking Tools Software
- Hacker Tools Free Download
- Hack Tools For Ubuntu
- Hack Tools For Ubuntu
- Pentest Tools Nmap
- Pentest Tools List
- Hacker Tools Mac
- Hacks And Tools
- Hack Tools For Ubuntu
- Hacking Tools Download
- Hacking Tools Mac
- Ethical Hacker Tools
- Hacking Tools 2020
- Hack Rom Tools
- Pentest Tools Website
- Pentest Tools Windows
- Free Pentest Tools For Windows
- Hack Tools Download
- Github Hacking Tools
- Game Hacking
- Hacking Tools Usb
- Hacker Tools Apk Download
- Hack Tools Mac
- Pentest Reporting Tools
- Pentest Tools Download
- Hacking Tools For Windows Free Download
- Pentest Tools For Android
- Termux Hacking Tools 2019
- Hacking Tools For Kali Linux
- Hacking Tools Pc
- How To Hack
- Pentest Tools Nmap
- Hack Tools For Games
- Hacking Tools Online
- Physical Pentest Tools
Comentarios
Publicar un comentario