pic
This commit is contained in:
parent
5416ecd2c3
commit
8e6f1d8069
@ -18,7 +18,7 @@ categories: Pwn二进制漏洞
|
||||
- Metasploit框架-[下载](https://www.metasploit.com/)
|
||||
- 靶机–Windows XP sp3
|
||||
|
||||
data:image/s3,"s3://crabby-images/10b95/10b9550193fb2e29927b2c318eae880bb6a320b2" alt=""
|
||||
data:image/s3,"s3://crabby-images/b57ff/b57ffffa56899887907d781b41498e53de53953a" alt=""
|
||||
- 函数调用与栈:调用、返回
|
||||
- 寄存器与函数栈帧:ESP、EBP
|
||||
- 函数栈帧:局部变量、栈帧状态值、函数返回地址
|
||||
@ -46,7 +46,7 @@ voidfunc(int a, int b, int c)
|
||||
* pop ebp
|
||||
* RETN【弹出返回地址,跳转】
|
||||
3. 栈帧结构
|
||||
data:image/s3,"s3://crabby-images/77da8/77da89de315ae6e5dc19393da476db7050a49ef4" alt=""
|
||||
data:image/s3,"s3://crabby-images/44abb/44abb11d9a7282a9f73de1fd779d794aeb17552f" alt=""
|
||||
|
||||
# 0x01 简单栈溢出
|
||||
|
||||
@ -63,7 +63,7 @@ voidfunc(int a, int b, int c)
|
||||
> `quit`
|
||||
|
||||
## 漏洞点
|
||||
data:image/s3,"s3://crabby-images/0513e/0513ea8463d9e110cfc0ffb10278d644ca8e4c01" alt=""
|
||||
data:image/s3,"s3://crabby-images/52607/52607d601d1125e7a535b7d21505ca84561f1086" alt=""
|
||||
|
||||
**产生崩溃**
|
||||
将输出的1024个A发送给靶机程序
|
||||
@ -71,44 +71,44 @@ voidfunc(int a, int b, int c)
|
||||
python -c "print('A' * 1024)"
|
||||
telnet 192.168.64.138 4242
|
||||
```
|
||||
data:image/s3,"s3://crabby-images/72655/726551ec529b4d4a97d63281eeabe56df2c15159" alt=""
|
||||
data:image/s3,"s3://crabby-images/aabe3/aabe334f24f0dff52e8e8101ccd2545057f4fb83" alt=""
|
||||
|
||||
## 关闭防御措施
|
||||
使用**PESecurity**检查可执行文件本身的防御措施开启情况
|
||||
注意设置:Set-ExecutionPolicyUnrestricted
|
||||
|
||||
data:image/s3,"s3://crabby-images/97ec7/97ec75e4f6a89e489f20d797826128ebcac7719a" alt=""
|
||||
data:image/s3,"s3://crabby-images/48800/488007b13442771db4ccb8aaa16817d959c789e9" alt=""
|
||||
|
||||
**ASLR和DEP**
|
||||
ASLR在xp下不用考虑,DEP可通过修改boot.ini中的nonexecute来完成(AlwaysOff、OptOut)
|
||||
data:image/s3,"s3://crabby-images/88045/880454d7e29f079ff69e6e64863a794fb74a82a0" alt=""
|
||||
data:image/s3,"s3://crabby-images/4ee62/4ee6257f970c6e184c862f5f25c657150252e850" alt=""
|
||||
|
||||
## 整体的攻击流程
|
||||
1. 任意非00的指令覆盖buffer和EBP
|
||||
2. 从程序已经加载的dll中获取他们的jmp esp指令地址。
|
||||
3. 使用jmp esp的指令地址覆盖ReturnAddress
|
||||
4. 从下一行开始填充Shellcode
|
||||
data:image/s3,"s3://crabby-images/33a04/33a04b15dfbb38867df5a275c699a8ce62c529ee" alt=""
|
||||
data:image/s3,"s3://crabby-images/5ad92/5ad928c472f5360bee70f10c4c99de8d383b1dff" alt=""
|
||||
|
||||
## 确定溢出点的位置
|
||||
1. 生成字符序列 **pattern_create.rb**
|
||||
data:image/s3,"s3://crabby-images/42079/4207918c5d7a3e9820a90a0b39d3e17325b8f550" alt=""
|
||||
data:image/s3,"s3://crabby-images/f5f18/f5f181ac64a1f8a7c802f6055ede02240ead49f0" alt=""
|
||||
|
||||
2. 发送给目标程序
|
||||
data:image/s3,"s3://crabby-images/560ce/560cece275ba8b5058e16b3ae3f35217ba1f00a9" alt=""
|
||||
data:image/s3,"s3://crabby-images/6301b/6301bbc80cdf5b0da96e28cd2f629b7ba1d1b7ac" alt=""
|
||||
|
||||
3. 计算偏移量 **pattern_offset.rb**
|
||||
data:image/s3,"s3://crabby-images/47553/475533dab90b46bbcd1b4e02814a4b9b577024bc" alt=""
|
||||
data:image/s3,"s3://crabby-images/0db51/0db51034f0ccb96a8540ddcc0bc20a8f3f2d2327" alt=""
|
||||
|
||||
4. 确定payload结构
|
||||
data:image/s3,"s3://crabby-images/a783e/a783e1defffa8021dddd667045d77e7fb299d33d" alt=""
|
||||
data:image/s3,"s3://crabby-images/a0eec/a0eecebba838fc3759adc00c984f9b4b9aa80838" alt=""
|
||||
|
||||
## 寻找jmp esp跳板
|
||||
1. OD附加进程看一下服务器加载了哪些模块
|
||||
data:image/s3,"s3://crabby-images/07fe9/07fe9d346fb5bb198467edc1067591c887786935" alt=""
|
||||
data:image/s3,"s3://crabby-images/8cd12/8cd127079e2f47fe858aee2df13738382c275092" alt=""
|
||||
2. 查找JMP ESP指令的地址
|
||||
在这里选择了ws2_32.dll作为对象,通过Metasploit的msfbinscan进行搜索
|
||||
data:image/s3,"s3://crabby-images/7de0b/7de0b09b82624e772da4ab281d819f0be7913ff6" alt=""
|
||||
data:image/s3,"s3://crabby-images/c35ff/c35ff6263757384379ff86112752a99023a3d1b0" alt=""
|
||||
|
||||
## 自动化攻击
|
||||
```ruby=
|
||||
@ -226,7 +226,7 @@ vim -bz.txt
|
||||
- 将Easy File Sharing Web Server 7.2加载到ImmunityDebugger中,并处于运行状态。
|
||||
- 发送溢出字符序列
|
||||
- 查看Easy File Sharing Web Server 7.2溢出地址
|
||||
data:image/s3,"s3://crabby-images/826e1/826e1ce0b074360110ff756d80325dba25e36490" alt=""
|
||||
data:image/s3,"s3://crabby-images/a5ff3/a5ff303b5d2aa3caf2f17091db827367d071f07f" alt=""
|
||||
|
||||
3. 计算偏移量
|
||||
计算catch块偏移量&计算下一条SEH记录偏移量
|
||||
@ -325,7 +325,7 @@ Server username: WHU-3E3EECEBFD1\Administrator
|
||||
> **漏洞点** data:image/s3,"s3://crabby-images/75990/759900f99e544bfcfa1f6751c4997ee77b16e2b5" alt=""
|
||||
|
||||
## 设置DEP保护
|
||||
data:image/s3,"s3://crabby-images/c1a44/c1a449a04f7c5d6412d7a99345b01e5cf62bbea4" alt=""
|
||||
data:image/s3,"s3://crabby-images/3168f/3168f0caff10bb36949bf23a110f5c99b66cce11" alt=""
|
||||
*构建ROP链来调用VirtualProtect()关闭DEP并执行Shellcode*
|
||||
|
||||
## 计算偏移量
|
||||
|
Loading…
x
Reference in New Issue
Block a user