mirror of
https://github.com/nganhkhoa/CTF-All-In-One.git
synced 2024-12-25 11:41:16 +07:00
finish 8.1.4
This commit is contained in:
parent
61348864dd
commit
b4396439b2
@ -143,8 +143,13 @@ GitHub 地址:https://github.com/firmianay/CTF-All-In-One
|
|||||||
* [八、学术篇](doc/8_academic.md)
|
* [八、学术篇](doc/8_academic.md)
|
||||||
* Return-Oriented Programming
|
* Return-Oriented Programming
|
||||||
* [8.1.1 The Geometry of Innocent Flesh on the Bone: Return-into-libc without Function Calls (on the x86)](doc/8.1.1_return-into-libc_without_function_calls.md)
|
* [8.1.1 The Geometry of Innocent Flesh on the Bone: Return-into-libc without Function Calls (on the x86)](doc/8.1.1_return-into-libc_without_function_calls.md)
|
||||||
* [8.1.2 Return-Oriented Programming without Returns](doc/8.1.2_return-oriented_programming_without_returns.md)
|
* [8.1.2 Return-Oriented Programming without Returns](doc/8.1.2_rop_without_returns.md)
|
||||||
* [8.1.3 Return-Oriented Rootkits: Bypassing Kernel Code Integrity Protection Mechanisms](doc/8.1.3_return-oriented_rootkits.md)
|
* [8.1.3 Return-Oriented Rootkits: Bypassing Kernel Code Integrity Protection Mechanisms](doc/8.1.3_return-oriented_rootkits.md)
|
||||||
|
* [8.1.4 ROPdefender: A Detection Tool to Defend Against Return-Oriented Programming Attacks](doc/8.1.4_ropdefender.md)
|
||||||
|
* Symbolic Execution
|
||||||
|
* [8.2.1 All You Ever Wanted to Know About Dynamic Taint Analysis and Forward Symbolic Execution (but might have been afraid to ask)](doc/8.2.1_dynamic_taint_analysis.md)
|
||||||
|
* [8.2.2 Symbolic Execution for Software Testing: Three Decades Later](doc/8.2.2_symbolic_execution_for_software_testing.md)
|
||||||
|
* Code Obfuscation
|
||||||
* Reverse Engineering
|
* Reverse Engineering
|
||||||
* [8.3 New Frontiers of Reverse Engineering](doc/8.3_new_frontiers_of_reverse_engineering.md)
|
* [8.3 New Frontiers of Reverse Engineering](doc/8.3_new_frontiers_of_reverse_engineering.md)
|
||||||
* Android Security
|
* Android Security
|
||||||
|
@ -50,7 +50,7 @@ blx r5
|
|||||||
|
|
||||||
由于 update-load-branch 指令序列相比 return 指令更加稀少,所以需要把它作为 trampoline 重复利用。在构造 ROP 链时,选择以 trampoline 为目标的间接跳转指令结束的指令序列。当一个 gadget 执行结束后,跳转到 trampoline,trampoline 更新程序全局状态,并将程序控制交给下一个 gadget,这样就形成了 ROP 链。
|
由于 update-load-branch 指令序列相比 return 指令更加稀少,所以需要把它作为 trampoline 重复利用。在构造 ROP 链时,选择以 trampoline 为目标的间接跳转指令结束的指令序列。当一个 gadget 执行结束后,跳转到 trampoline,trampoline 更新程序全局状态,并将程序控制交给下一个 gadget,这样就形成了 ROP 链。
|
||||||
|
|
||||||
![](../pic/8.2_rop_without_ret.png)
|
![](../pic/8.1.2_rop_without_ret.png)
|
||||||
|
|
||||||
|
|
||||||
## 参考资料
|
## 参考资料
|
||||||
|
57
doc/8.1.4_ropdefender.md
Normal file
57
doc/8.1.4_ropdefender.md
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
# 8.1.4 ROPdefender: A Detection Tool to Defend Against Return-Oriented Programming Attacks
|
||||||
|
|
||||||
|
|
||||||
|
## 简介
|
||||||
|
论文设计并实现了工具 ROPdefender,可以动态地检测传统的 ROP 攻击(基于return指令)。ROPdefender 可以由用户来执行,而不依赖于源码、调试信息等在现实中很难获得的信息。
|
||||||
|
|
||||||
|
ROPdefender 基于二进制插桩框架 Pin 实现,作为一个 Pintool 使用,在运行时强制进行返回地址检查。
|
||||||
|
|
||||||
|
|
||||||
|
## 背景
|
||||||
|
现有的 ROP 检测方法会维护一个 shadow stack,作为返回地址的备份。当函数返回时,检查返回地址是否被修改。
|
||||||
|
|
||||||
|
这种方法有个明显的缺陷,它只能检测预期的返回(intended return),而对于非预期的返回(unintended return)无效。
|
||||||
|
|
||||||
|
intended instruction 是程序中明确存在的指令。而 unintended instruction 是正常指令通过偏移得到的指令。举个例子:
|
||||||
|
|
||||||
|
intended instruction:
|
||||||
|
```
|
||||||
|
b8 13 00 00 00 mov $0x13, %eax
|
||||||
|
e9 c3 f8 ff ff jmp 3aae9
|
||||||
|
```
|
||||||
|
偏移两个十六进制后的 unintended instruction:
|
||||||
|
```
|
||||||
|
00 00 add %al, (%eax)
|
||||||
|
00 e9 add %ch, %cl
|
||||||
|
c3 ret
|
||||||
|
```
|
||||||
|
|
||||||
|
这样的返回不会被备份到 shadow stack 中,因此也不会被检测到。
|
||||||
|
|
||||||
|
另外,如果攻击者修改的不是返回地址,而是函数的 GOT 表,则同样不会被检测到。
|
||||||
|
|
||||||
|
|
||||||
|
## 解决方案
|
||||||
|
ROPdefender 同样也使用 shadow stack 来储存每次函数调用的返回地址。在每次函数返回时进行返回地址检查。
|
||||||
|
|
||||||
|
与现有方法不同的是:
|
||||||
|
- ROPdefender 会检查传递给处理器的每个返回指令(基于JIT插桩工具),这样即使攻击者使用 unintended instruction 也会被检测到
|
||||||
|
- ROPdefender 还能处理各种特殊的情况
|
||||||
|
|
||||||
|
整体思想如下图所示:
|
||||||
|
|
||||||
|
![](../pic/8.1.4_approach.png)
|
||||||
|
|
||||||
|
在处理器执行指令时,对指令类别进行判断,如果是 call,将返回地址放进 shadow stack;如果是 return,则检查与 shadow stack 顶部的返回地址是否相同。这一方法不仅可用于检测 ROP 攻击,还可以检测所有利用缓冲区溢出改写返回地址的攻击。
|
||||||
|
|
||||||
|
|
||||||
|
## 实现细节
|
||||||
|
基于 Pin 动态二进制插桩(DBI)框架的实现如下图所示:
|
||||||
|
|
||||||
|
![](../pic/8.1.4_implementation.png)
|
||||||
|
|
||||||
|
一般工作流程是这样的,程序在 DBI 框架下加载并启动。DBI 框架确保:
|
||||||
|
1. 程序的每条指令都在 DBI 的控制下执行
|
||||||
|
2. 所有指令都根据 ROPdefender 特定的检测代码执行,然后进行返回地址检查
|
||||||
|
|
||||||
|
ROPdefender 包含了多个 shadow stack 和一个 detection unit。detection unit 用于 shadow stack 返回地址的压入和弹出,并进行强制返回地址检查。使用多个 shadow stack 的原因是程序可能会有多个线程,这样就可以为每个线程都维护一个 shadow stack。
|
1
doc/8.2.1_dynamic_taint_analysis.md
Normal file
1
doc/8.2.1_dynamic_taint_analysis.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# 8.2.1 All You Ever Wanted to Know About Dynamic Taint Analysis and Forward Symbolic Execution (but might have been afraid to ask)
|
1
doc/8.2.2_symbolic_execution_for_software_testing.md
Normal file
1
doc/8.2.2_symbolic_execution_for_software_testing.md
Normal file
@ -0,0 +1 @@
|
|||||||
|
# 8.2.2 Symbolic Execution for Software Testing: Three Decades Later
|
@ -5,8 +5,12 @@
|
|||||||
|
|
||||||
* Return-Oriented Programming
|
* Return-Oriented Programming
|
||||||
* [8.1.1 The Geometry of Innocent Flesh on the Bone: Return-into-libc without Function Calls (on the x86)](doc/8.1.1_return-into-libc_without_function_calls.md)
|
* [8.1.1 The Geometry of Innocent Flesh on the Bone: Return-into-libc without Function Calls (on the x86)](doc/8.1.1_return-into-libc_without_function_calls.md)
|
||||||
* [8.1.2 Return-Oriented Programming without Returns](doc/8.1.2_return-oriented_programming_without_returns.md)
|
* [8.1.2 Return-Oriented Programming without Returns](doc/8.1.2_rop_without_returns.md)
|
||||||
* [8.1.3 Return-Oriented Rootkits: Bypassing Kernel Code Integrity Protection Mechanisms](doc/8.1.3_return-oriented_rootkits.md)
|
* [8.1.3 Return-Oriented Rootkits: Bypassing Kernel Code Integrity Protection Mechanisms](doc/8.1.3_return-oriented_rootkits.md)
|
||||||
|
* [8.1.4 ROPdefender: A Detection Tool to Defend Against Return-Oriented Programming Attacks](doc/8.1.4_ropdefender.md)
|
||||||
|
* Symbolic Execution
|
||||||
|
* [8.2.1 All You Ever Wanted to Know About Dynamic Taint Analysis and Forward Symbolic Execution (but might have been afraid to ask)](doc/8.2.1_dynamic_taint_analysis.md)
|
||||||
|
* [8.2.2 Symbolic Execution for Software Testing: Three Decades Later](doc/8.2.2_symbolic_execution_for_software_testing.md)
|
||||||
* Reverse Engineering
|
* Reverse Engineering
|
||||||
* [8.3 New Frontiers of Reverse Engineering](doc/8.3_new_frontiers_of_reverse_engineering.md)
|
* [8.3 New Frontiers of Reverse Engineering](doc/8.3_new_frontiers_of_reverse_engineering.md)
|
||||||
* Android Security
|
* Android Security
|
||||||
|
BIN
pic/8.1.4_approach.png
Normal file
BIN
pic/8.1.4_approach.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 39 KiB |
BIN
pic/8.1.4_implementation.png
Normal file
BIN
pic/8.1.4_implementation.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 62 KiB |
Loading…
Reference in New Issue
Block a user