C++ Std::String Buffer Overflow And Integer Overflow
Interators are usually implemented using signed integers like the typical "for (int i=0; ..." and in fact is the type used indexing "cstr[i]", most of methods use the signed int, int by default is signed.
Nevertheless, the "std::string::operator[]" index is size_t which is unsigned, and so does size(), and same happens with vectors.
Besides the operator[] lack of negative index control, I will explain this later.
Do the compilers doesn't warn about this?
If his code got a large input it would index a negative numer, let see g++ and clang++ warnings:
No warnings so many bugs out there...
In order to reproduce the crash we can load a big string or vector from file, for example:
I've implemented a loading function, getting the file size with tellg() and malloc to allocate the buffer, then in this case used as a string.
Let see how the compiler write asm code based on this c++ code.
So the string constructor, getting size and adding -2 is clear. Then come the operator<< to concat the strings.
Then we see the operator[] when it will crash with the negative index.
In assembly is more clear, it will call operator[] to get the value, and there will hapen the magic dereference happens. The operator[] will end up returning an invalid address that will crash at [RAX]
In gdb the operator[] is a allq 0x555555555180 <_znst7__cxx1112basic_stringicst11char_traitsicesaiceeixem plt="">
(gdb) i r rsi
rsi 0xfffffffffffefffe -65538
The implmementation of operator ins in those functions below:
(gdb) bt
#0 0x00007ffff7feebf3 in strcmp () from /lib64/ld-linux-x86-64.so.2
#1 0x00007ffff7fdc9a5 in check_match () from /lib64/ld-linux-x86-64.so.2
#2 0x00007ffff7fdce7b in do_lookup_x () from /lib64/ld-linux-x86-64.so.2
#3 0x00007ffff7fdd739 in _dl_lookup_symbol_x () from /lib64/ld-linux-x86-64.so.2
#4 0x00007ffff7fe1eb7 in _dl_fixup () from /lib64/ld-linux-x86-64.so.2
#5 0x00007ffff7fe88ee in _dl_runtime_resolve_xsavec () from /lib64/ld-linux-x86-64.so.2
#6 0x00005555555554b3 in main (argc=2, argv=0x7fffffffe118) at main.cpp:29
29 cout << "penultimate byte is " << hex << s[i] << endl;
(gdb)
What about negative indexing in std::string::operator[] ?
It's exploitable!
In a C char array is known that having control of the index, we can address memory.
Let's see what happens with C++ strings:
The operator[] function call returns the address of string plus 10, and yes, we can do abitrary writes.
Note that gdb displays by default with at&t asm format wich the operands are in oposite order:
And having a string that is in the stack, controlling the index we can perform a write on the stack.
To make sure we are writing outside the string, I'm gonna do 3 writes:
See below the command "i r rax" to view the address where the write will be performed.
The beginning of the std::string object is 0x7fffffffde50.
Write -10 writes before the string 0x7fffffffde46.
And write -100 segfaults because is writting in non paged address.
So, C++ std::string probably is not vulnerable to buffer overflow based in concatenation, but the std::string::operator[] lack of negative indexing control and this could create vulnerable and exploitable situations, some times caused by a signed used of the unsigned std::string.size()
Nevertheless, the "std::string::operator[]" index is size_t which is unsigned, and so does size(), and same happens with vectors.
Besides the operator[] lack of negative index control, I will explain this later.
Do the compilers doesn't warn about this?
If his code got a large input it would index a negative numer, let see g++ and clang++ warnings:
No warnings so many bugs out there...
In order to reproduce the crash we can load a big string or vector from file, for example:
I've implemented a loading function, getting the file size with tellg() and malloc to allocate the buffer, then in this case used as a string.
Let see how the compiler write asm code based on this c++ code.
So the string constructor, getting size and adding -2 is clear. Then come the operator<< to concat the strings.
Then we see the operator[] when it will crash with the negative index.
In assembly is more clear, it will call operator[] to get the value, and there will hapen the magic dereference happens. The operator[] will end up returning an invalid address that will crash at [RAX]
In gdb the operator[] is a allq 0x555555555180 <_znst7__cxx1112basic_stringicst11char_traitsicesaiceeixem plt="">
(gdb) i r rsi
rsi 0xfffffffffffefffe -65538
The implmementation of operator ins in those functions below:
(gdb) bt
#0 0x00007ffff7feebf3 in strcmp () from /lib64/ld-linux-x86-64.so.2
#1 0x00007ffff7fdc9a5 in check_match () from /lib64/ld-linux-x86-64.so.2
#2 0x00007ffff7fdce7b in do_lookup_x () from /lib64/ld-linux-x86-64.so.2
#3 0x00007ffff7fdd739 in _dl_lookup_symbol_x () from /lib64/ld-linux-x86-64.so.2
#4 0x00007ffff7fe1eb7 in _dl_fixup () from /lib64/ld-linux-x86-64.so.2
#5 0x00007ffff7fe88ee in _dl_runtime_resolve_xsavec () from /lib64/ld-linux-x86-64.so.2
#6 0x00005555555554b3 in main (argc=2, argv=0x7fffffffe118) at main.cpp:29
Then crashes on the MOVZX EAX, byte ptr [RAX]
Program received signal SIGSEGV, Segmentation fault.
0x00005555555554b3 in main (argc=2, argv=0x7fffffffe118) at main.cpp:2929 cout << "penultimate byte is " << hex << s[i] << endl;
(gdb)
What about negative indexing in std::string::operator[] ?
It's exploitable!
In a C char array is known that having control of the index, we can address memory.
Let's see what happens with C++ strings:
The operator[] function call returns the address of string plus 10, and yes, we can do abitrary writes.
Note that gdb displays by default with at&t asm format wich the operands are in oposite order:
And having a string that is in the stack, controlling the index we can perform a write on the stack.
To make sure we are writing outside the string, I'm gonna do 3 writes:
The beginning of the std::string object is 0x7fffffffde50.
Write -10 writes before the string 0x7fffffffde46.
And write -100 segfaults because is writting in non paged address.
So, C++ std::string probably is not vulnerable to buffer overflow based in concatenation, but the std::string::operator[] lack of negative indexing control and this could create vulnerable and exploitable situations, some times caused by a signed used of the unsigned std::string.size()
More articles
- Game Hacking
- Hacker Tools For Windows
- Hacker Tools Free Download
- Hacking Tools For Windows
- Hacking Tools For Mac
- Termux Hacking Tools 2019
- What Is Hacking Tools
- Hacker Security Tools
- Pentest Tools For Android
- Usb Pentest Tools
- Hacker Tools For Ios
- Pentest Tools Apk
- Hack Tools Pc
- Hack Rom Tools
- Hack Tool Apk
- Hacker Tool Kit
- Pentest Tools Download
- Physical Pentest Tools
- Hack Apps
- Pentest Tools Find Subdomains
- Hacking Tools Hardware
- Android Hack Tools Github
- Pentest Tools List
- Hacking Tools Software
- Hacking Tools
- Hacker Tools
- Pentest Tools Url Fuzzer
- Underground Hacker Sites
- Hack Tools Github
- Pentest Tools For Windows
- Hacking Tools For Mac
- Hack Tools Mac
- Computer Hacker
- Hacking Tools For Windows Free Download
- Hack Tools
- Hacking Tools Online
- Usb Pentest Tools
- Hacker Tools Apk Download
- Hack Tools For Mac
- Blackhat Hacker Tools
- Hackers Toolbox
- Physical Pentest Tools
- Pentest Tools Port Scanner
- Pentest Tools Download
- Hacker Tools Online
- Growth Hacker Tools
- Underground Hacker Sites
- Best Hacking Tools 2020
- Hacking Tools Online
- Hacker Tools Github
- Hacker Security Tools
- Hack Tools
- Underground Hacker Sites
- Hack Tools Pc
- Hack Tools For Windows
- Hacker Tools Free Download
- Hacker Tools
- Hacker Tools For Mac
- Hacking Tools For Windows Free Download
- Hacking Tools 2020
- Hacking Tools Name
- Pentest Tools For Mac
- Hackers Toolbox
- Best Hacking Tools 2020
- Hacking Apps
- Top Pentest Tools
- Nsa Hack Tools Download
- Top Pentest Tools
- Hack Tools Mac
- Pentest Tools List
- Pentest Tools Url Fuzzer
- Best Pentesting Tools 2018
- Pentest Tools Website Vulnerability
- Hacker Tools
- Tools 4 Hack
- Hacking Tools Mac
- Wifi Hacker Tools For Windows
- Top Pentest Tools
- Pentest Tools Bluekeep
- Hacking Tools 2019
- Hack Tools For Windows
- Hacking Tools
- Hack Tools For Games
- Pentest Tools Subdomain
- Hack Apps
- Pentest Tools Free
- Hacker Tools Apk Download
- Pentest Box Tools Download
- Best Pentesting Tools 2018
- Pentest Tools Download
- Pentest Recon Tools
- Hack Tools Mac
- Install Pentest Tools Ubuntu
- Hacker Tools Apk Download
- Pentest Tools For Windows
- Hacker Tools Apk
- Hacker Security Tools
- Hacker Tools Hardware
- Pentest Tools For Windows
- Hacking Tools 2020
- Pentest Tools Linux
- Pentest Reporting Tools
- Hacking Tools 2019
- Hacking Tools 2020
- Android Hack Tools Github
- Hack Tools For Mac
- Hacking Tools Windows
- Pentest Automation Tools
- Install Pentest Tools Ubuntu
- Usb Pentest Tools
- Hacking Tools Hardware
- Hacking Tools Windows 10
- Game Hacking
- Pentest Tools List
- Hacker Tools Github
- Hacking Tools Usb
- How To Hack
- New Hack Tools
- Hacking Tools
- Hackers Toolbox
- Hak5 Tools
- Hacker Hardware Tools
- Hacking Tools Online
- Tools 4 Hack
- Hacker Tools Software
- Hacker Tools
- Pentest Tools For Windows
- Hacker Tools Free Download
- How To Install Pentest Tools In Ubuntu
- Kik Hack Tools
- Pentest Box Tools Download
- Hackers Toolbox
- Hacking Tools Windows
- Pentest Tools Alternative
- What Is Hacking Tools
- Best Hacking Tools 2020
- Termux Hacking Tools 2019
- Hacking Tools Software
- Nsa Hacker Tools
- New Hacker Tools
- Pentest Tools Alternative
- Pentest Tools Android
- Ethical Hacker Tools
- Pentest Tools For Ubuntu
- Hacking Tools And Software
- Pentest Tools For Android
- Physical Pentest Tools
- Black Hat Hacker Tools
- Hacking Tools And Software
- Hacking Tools For Pc
- Growth Hacker Tools
- Hak5 Tools
- Hacking Tools Hardware
- Hack Tools Download
- Wifi Hacker Tools For Windows
- Best Hacking Tools 2020
- Hackrf Tools
- Black Hat Hacker Tools
- Pentest Tools Kali Linux
- Nsa Hack Tools Download
- Hacking Tools For Windows
- Best Hacking Tools 2019
- Game Hacking
Post a Comment