自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

網(wǎng)絡(luò)安全編程:C語言逆向之if…else…結(jié)構(gòu)分析

安全
本文介紹了C語言逆向之if…else…的結(jié)構(gòu)分析 ,希望能幫到你。

 [[391871]]

. if…else…分支結(jié)構(gòu)例子程序

首先來寫一個簡單的C語言代碼例子,然后對例子代碼進(jìn)行介紹。例子代碼如下: 

  1. #include <stdio.h>  
  2. int main()  
  3.  
  4.  int a = 0b = 1c = 2 
  5.  if ( a > b )  
  6.  {  
  7.  printf("%d \r\n", a);  
  8.  }  
  9.  else if ( b <= c )  
  10.  {  
  11.  printf("%d \r\n", b);  
  12.  }  
  13.  else  
  14.  {  
  15.  printf("%d \r\n", c);  
  16.  }  
  17.  return 0;  

2. 逆向反匯編解析

上述代碼非常短且很簡單,用IDA看其反匯編代碼。固定模式的頭部和尾部位置省略不看,主要看其關(guān)鍵的反匯編代碼,具體如下: 

  1. .text:00401028 mov [ebp+var_4], 0  
  2. .text:0040102F mov [ebp+var_8], 1  
  3. .text:00401036 mov [ebp+var_C], 2 

以上3行反匯編代碼是對定義的變量的初始化,在IDA中可以通過快捷鍵將其重命名。將以上3個變量重命名后,看其余的反匯編代碼,具體如下: 

  1. .text:0040103D mov eax, [ebp+var_4]  
  2. .text:00401040 cmp eax, [ebp+var_8]  
  3. .text:00401043 jle short loc_401058  
  4. .text:00401045 mov ecx, [ebp+var_4]  
  5. .text:00401048 push ecx  
  6. .text:00401049 push offset Format ; "%d \r\n"  
  7. .text:0040104E call _printf  
  8. .text:00401053 add esp, 8  
  9. .text:00401056 jmp short loc_401084  
  10. .text:00401058 ; -------------------------------------------------  
  11. .text:00401058  
  12. .text:00401058 loc_401058: ; CODE XREF: _main+33j  
  13. .text:00401058 mov edx, [ebp+var_8]  
  14. .text:0040105B cmp edx, [ebp+var_C]  
  15. .text:0040105E jg short loc_401073  
  16. .text:00401060 mov eax, [ebp+var_8]  
  17. .text:00401063 push eax  
  18. .text:00401064 push offset Format ; "%d \r\n"  
  19. .text:00401069 call _printf  
  20. .text:0040106E add esp, 8  
  21. .text:00401071 jmp short loc_401084  
  22. .text:00401073 ; --------------------------------------------------  
  23. .text:00401073 
  24. .text:00401073 loc_401073: ; CODE XREF: _main+4Ej  
  25. .text:00401073 mov ecx, [ebp+var_C] 
  26. .text:00401076 push ecx  
  27. .text:00401077 push offset Format ; "%d \r\n"  
  28. .text:0040107C call _printf  
  29. .text:00401081 add esp, 8  
  30. .text:00401084  
  31. .text:00401084 loc_401084: ; CODE XREF: _main+46j  
  32. .text:00401084 ; _main+61j 

將以上反匯編分為3段進(jìn)行觀察,第1段的地址范圍是0040103D至00401056,第2段的地址范圍是00401058至00401071,第3段的地址范圍是00401073至00401081。除了第3段代碼外,前面兩段的代碼有一個共同的特征:cmp / jxx / printf / jmp。這部分功能的特征就是if…else…的特征所在。看一下IDA繪制的該段反匯編代碼的反匯編流程結(jié)構(gòu),如圖1所示。

圖1  if…else…反匯編流程結(jié)構(gòu)

在C語言代碼中,影響程序流程的是兩個關(guān)鍵的比較,分別是“>”和“<=”。在反匯編代碼中,影響主要流程的是兩個條件跳轉(zhuǎn)指令,分別是“jle”和“jg”。C語言代碼中,“>”(大于號)在反匯編中對應(yīng)的是“jle”(小于等于則跳轉(zhuǎn)),“<=”(小于等于號)在反匯編中對應(yīng)的是“jg”(大于則跳轉(zhuǎn))。

注意觀察00401043和0040105E這兩個地址,jxx指令會跳過緊接著其后面的指令部分,而跳轉(zhuǎn)的目的地址上面都有一條jmp無條件跳轉(zhuǎn)指令。也就是說,jxx和jmp之間的部分是C語言代碼中比較表達(dá)式成功后執(zhí)行的代碼。在反匯編代碼中,如果條件跳轉(zhuǎn)指令沒有發(fā)生跳轉(zhuǎn),則執(zhí)行其后的指令。這樣的反匯編指令與C語言的流程是相同的。當(dāng)條件跳轉(zhuǎn)指令發(fā)生跳轉(zhuǎn)后,執(zhí)行完相應(yīng)的指令后會執(zhí)行jmp指令跳到某個地址。注意觀察,兩條jmp跳轉(zhuǎn)的目的地址都為00401084。

3. if…else…結(jié)構(gòu)小結(jié)

從例子中可以找出C語言if…else…結(jié)構(gòu)與反匯編代碼的對應(yīng)結(jié)構(gòu),具體如下: 

  1. ; 初始化變量  
  2.  mov xxx, xxx  
  3.  mov xxx, xxx  
  4.  ; 比較跳轉(zhuǎn)  
  5.  cmp xxx, xxx  
  6.  jxx _else_if  
  7.  ; 一系列處理指令  
  8.  ……  
  9.  jmp _if_else 結(jié)束位置  
  10. _else_if:  
  11.  mov xxx, xxx  
  12.  ; 比較跳轉(zhuǎn)  
  13.  cmp xxx, xxx  
  14.  jxx _else  
  15.  ; 一系列處理治理  
  16.  ……  
  17.  jmp _if_else 結(jié)束位置  
  18. _else:  
  19.  ; 一系列處理指令  
  20.  ……  
  21.  _if_else 結(jié)束位置: 

以上就是if…else…分支結(jié)構(gòu)的大體形式。 

 

責(zé)任編輯:龐桂玉 來源: 計(jì)算機(jī)與網(wǎng)絡(luò)安全
相關(guān)推薦

2021-04-13 11:15:54

網(wǎng)絡(luò)安全C語言循環(huán)結(jié)構(gòu)

2021-04-14 15:53:58

網(wǎng)絡(luò)安全C語言wcslen

2021-04-06 11:04:54

網(wǎng)絡(luò)安全C語言代碼

2021-03-31 11:35:00

網(wǎng)絡(luò)安全OllyDbg分析工具

2021-04-01 10:40:22

網(wǎng)絡(luò)安全軟件

2016-10-10 00:18:27

2021-04-19 10:26:41

網(wǎng)絡(luò)安全PE文件

2011-03-17 11:24:18

2021-03-24 09:46:46

網(wǎng)絡(luò)安全軟件反匯編

2011-03-17 13:32:45

2021-04-27 10:00:27

網(wǎng)絡(luò)安全WebURL

2011-03-17 12:49:32

2021-03-03 12:20:42

網(wǎng)絡(luò)安全DLL編程

2021-05-21 12:52:47

網(wǎng)絡(luò)安全Android App虛擬機(jī)

2021-04-26 10:32:38

網(wǎng)絡(luò)安全PE編程工具

2021-04-30 18:50:44

網(wǎng)絡(luò)安全PE編程添加節(jié)區(qū)

2021-12-28 00:11:40

網(wǎng)絡(luò)安全攻擊

2021-01-26 13:45:03

網(wǎng)絡(luò)安全Winsock編程

2021-03-05 13:46:56

網(wǎng)絡(luò)安全遠(yuǎn)程線程

2021-04-25 21:25:09

網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全編程PE編程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號