(13)中斷門
一、中斷門描述符
可以看到,中斷門的結構和呼叫門非常像,主要是TYPE域,0x6表示16位中斷門,0xE表示32位中斷門。和呼叫門不同,中斷門不能傳參。
中斷門儲存在IDT表中,IDT表除了儲存中斷門描述符,還有任務門和陷阱門描述符。
使用呼叫門的方法是 CALL FAR,而使用中斷門的方法是 INT N,其中,N表示中斷門描述符在IDT表中的下標。
和呼叫門一樣,中斷門也可以用來提權。不提權時,INT N 會依次壓棧CS,EFLAG EIP;提權時,會依次壓棧 SS ESP EFLAG CS EIP。這說明使用中斷門會對EFLAG進行修改。
二、自己實現中斷門
首先定義一個裸函式,在裡面讀取一下IDT表的第一項,以證明自己的CPL是0.
// INTGate.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <Windows.h>
#include <stdio.h>
BYTE IDTItem0[8];
// R0 函式,讀取了IDT表第一項
// 004113A0
void __declspec(naked) R0Function()
{
__asm
{
//int 3 // 除錯用的
pushad
pushfd
mov eax,0x8003f400
mov ebx,[eax]
mov ecx,[eax+0x4]
mov dword ptr ds:[IDTItem0],ebx
mov dword ptr ds:[IDTItem0+0x4],ecx
popfd
popad
iretd // iret 會藍屏,因為 iret的硬編碼是66CF,32位下應該使用iretd,硬編碼是CF
}
}
int _tmain(int argc, _TCHAR* argv[])
{
__asm
{
INT 0x20
}
printf("%08x %08x\n", *(PDWORD)IDTItem0, *(PDWORD)((PBYTE)IDTItem0+0x4));
getchar();
return 0;
}
然後構造一個提權中斷門,DPL可以是0或3,都試試:
0041 13A0
0041EE00`000813A0
eq 8003f500 0041EE00`000813A0
00418E00`000813A0
eq 8003f500 00418E00`000813A0
然後在IDT表裡尋找一個P=0的無效項,把我們設計的第一個中斷門描述符填進去:
這裡下標是0x20,所以中斷指令是 INT 0x20,執行結果如下:
這個是DPL=3的版本,然後我們再試試DPL=0:
發現被當成無效中斷了:
於是,得出結論,CPL=DPL時,才能成功觸發中斷。
三、在呼叫門中實現使用IRETD返回,在中斷門中實現用RETF返回.
在中斷門中用RETF返回,只需將[ESP+0x8]寫到EFLAG,然後讓ESP 和 SS向低地址移動4位元組即可。
// INTGate.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <Windows.h>
#include <stdio.h>
BYTE IDTItem0[8];
// R0 函式,讀取了IDT表第一項
// 004113A0
void __declspec(naked) R0Function()
{
__asm
{
//int 3 // 除錯用的
pushad
pushfd
mov eax,0x8003f400
mov ebx,[eax]
mov ecx,[eax+0x4]
mov dword ptr ds:[IDTItem0],ebx
mov dword ptr ds:[IDTItem0+0x4],ecx
// 要求用 retf 返回
add esp,0x2c // esp指向eflags
popfd // esp指向3環esp
mov eax,[esp] // 將原ESP和SS向低地址移動4位元組
mov [esp-0x4],eax
mov eax,[esp+0x4]
mov [esp],eax
sub esp,0x30 // 還原esp
popfd
popad
retf
}
}
int _tmain(int argc, _TCHAR* argv[])
{
__asm
{
INT 0x20
}
printf("%08x %08x\n", *(PDWORD)IDTItem0, *(PDWORD)((PBYTE)IDTItem0+0x4));
getchar();
return 0;
}
在呼叫門中用IRETD返回,只需將ESP和SS向高地址移動4位元組,將EFLAG寫到[ESP+0x8]即可。
// INTGate.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include <windows.h>
#include <stdio.h>
DWORD dwHigh2GValue;
// 該函式通過 CALL FAR 呼叫,使用呼叫門提權,擁有0環許可權
// 00411480
void __declspec(naked) FunctionHas0CPL()
{
__asm
{
pushad
pushfd
// 讀取了GDT表第二項的低4位元組
mov eax,0x8003f008
mov eax,[eax]
mov dwHigh2GValue,eax
// 要求用 iretd 返回
add esp,0x30 // esp指向ss
mov eax,[esp] // 將原ESP和SS向高地址移動4位元組
mov [esp+0x4],eax
mov eax,[esp-0x4]
mov [esp],eax
pushfd
sub esp,0x2c // 還原esp
popfd
popad
iretd
}
}
int main(int argc, char* argv[])
{
char buff[6] = {0,0,0,0,0x48,0};
__asm
{
call fword ptr [buff] // 長呼叫,使用呼叫門提權
}
printf("%08x\n",dwHigh2GValue);
getchar();
return 0;
}
相關文章
- LINUX中斷--申請中斷和解除安裝中斷Linux
- 中斷和中斷處理程式
- 中斷
- 5分鐘入門 next13
- vue 基礎入門筆記 13Vue筆記
- 硬中斷,軟中斷,訊號,異常
- Java入門系列-13-String 和 StringBufferJava
- Python入門 - 判斷語句Python
- 2020-12-13——門面模式在MyBatis以及Tomcat原始碼中的應用模式MyBatisTomcat原始碼
- minos 2.4 中斷虛擬化——中斷子系統
- 原來定時器中斷是個偽中斷定時器
- 前端入門13-JavaScript進階之原型前端JavaScript原型
- 最熱門的13個Java微服務框架Java微服務框架
- [ARKit]13-[譯]在ARKit中建立一個時空門App:材質和光照APP
- baremetal GPIO中斷REM
- 28388_中斷
- 缺頁中斷
- 『言善信』Fiddler工具 — 13、Fiddler斷點功能的使用詳解斷點
- 13 個示例快速入門 JS 抽象語法樹JS抽象語法樹
- (13)mysql 中的流程控制MySql
- Go語言開發面試題分享:(判斷題13道)(6)Go面試題
- Linux中斷申請Linux
- Java中斷機制Java
- linux中斷 簡介Linux
- SMP PPI中斷使用
- 異常和中斷
- 聊聊中斷機制~
- kubernetes之pod中斷
- EXTI-外部中斷
- 0166-BIOS 中斷iOS
- Cortex-A系列中斷
- Linux核心軟中斷Linux
- 如果尚未切換到HTTPS,從2020年1月13日開始,Maven構建可能會中斷 -Alphabot安全HTTPMaven
- C#快速入門教程(13)—— switch語句結構C#
- 【asp.net core 系列】13 Identity 身份驗證入門ASP.NETIDE
- 13個使用WebAssembly的熱門語言專案 - infoworldWeb
- js函式中的if判斷和a==b判斷JS函式
- July 30-day13-Python中PygamePythonGAM