Introduction to SQL Injection
Stefan Friese
11 April, 2024
Topics
- How an SQL Injection is Created
- How to Exploit an SQL Injection
- SPOILER: How to Prevent an SQL Injection in the
Next Presentation
How Does it Happen
An SQL injection occurs when two things come together.
Number 1
An SQL Query as a string embedded in other languages
sql_query =
cursor.execute(
"SELECT * FROM user_data where username = 'foo' and password = 's3cur3P4ssw0rd"
)
Number 2
User input is possible as a part of said SQL query
sql_query = cursor.execute("SELECT * FROM user_data where username = '%s'" % username)
How to Exploit an SQL
Injection
Work is a product of power by time.
P
is your power to solve an issue.
W = P x t
The smarter you tackle work, the less time you need to solve an
issue.
Knowledge is a Map
You conventiently drive around the city using the underground. That’s
how you get to know the main spots of the city.
data:image/s3,"s3://crabby-images/e70bb/e70bb48454644a8c45873e9179f47742a0da3450" alt="London Underground"
Knowledge is a Map
Invest some time and explore deeper on foot. That’s how you get to
know the back alleys.
data:image/s3,"s3://crabby-images/74ac8/74ac8fe73933aa49285f7600caaa17c6ff3d4c68" alt="London by Foot"
Main View of Ghidra
Watch Out for Low Hanging
Fruits
- Data Segment
- Names of Functions
- Conditions & Comparisons
- Strings: Usernames, Passwords
- URLs, IP & Port Numbers
Do not try to understand the whole code at once, it will only
drive you mad.
Data Segments
data:image/s3,"s3://crabby-images/c2111/c2111c538a68dd385b3e9410884e6f59e9ec889a" alt="A look into the read only data segment"
A look into the read only data segment
Name of Functions
Functions contained in the binary a.k.a.
Symbol Tree
Conditions & Comparisions
data:image/s3,"s3://crabby-images/18ff7/18ff7d0756c727499dc05eefa30c0d4947074c95" alt="Input is Compared to a Hard Coded String"
Input is compared to a hard coded string
Function Graph
data:image/s3,"s3://crabby-images/de2c6/de2c6b7e713c436450c30e94ccc7a4dc5c3c7d35" alt="Take a Look at the Flow Graph of Functions"
Take a look at the flow graph of functions
Strings
data:image/s3,"s3://crabby-images/bcf3f/bcf3fde53df7df161973b2748a662dab1d68d540" alt="Open the Defined Strings Menu"
Strings can not only be located in data but also in other code
segments, sometimes obfuscated
Strings
An old friend
Binary Patching
Bypass any undesireable condition via a NOP
instruction.
data:image/s3,"s3://crabby-images/562cf/562cf3082f2fd48f649a7decf89a3f269cb2c900" alt="NOP, export your patched binary"
NOP, export your patched binary
What Exactly
might be Obfuscated in Your Code?
- Code Element Layers
- Layout
- Controls
- Data
- Methods
- Classes
- Component
- Library Calls
- Used Resources
- Application Layer
- DRM System
- Neural Networks
Techniques of Obfuscation
Packing
Compress binary data
ooooo ooo ooooooooo. ooooooo ooooo
`888' `8' `888 `Y88. `8888 d8'
888 8 888 .d88' Y888..8P
888 8 888ooo88P' `8888'
888 8 888 .8PY888.
`88. .8' 888 d8' `888b
`YbodP' o888o o888o o88888o
UPX Packer/Unpacker
Mangling
Library symbols in compiled code for data that have the same name
c++filt
_ZNSt7__cxx1114collate_bynameIcEC2ERKNS_12basic_stringIcSt11char_traitsIcESaIcEEEm
std::__cxx11::collate_byname::collate_byname(std::__cxx11::basic_string, std::allocator > const&, unsigned long)
Code Elements
- Adding Unnecessary Instructions
- Changing Control Flows
- Protecting Data
data:image/s3,"s3://crabby-images/f0236/f023662003053a9dddceadb9a6e09cc03f865c49" alt="Convoluted Code"