精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

聊一聊對一個 C# 商業程序的反反調試

開發 前端
經過和朋友的技術搗鼓之后,發現還好,對方只是用了 KERNELBASE!IsDebuggerPresent 做的反調試判斷,難度不大,這里就不細聊那個程序,我們做一個簡單的案例來說下如何反反調試,老規矩,上 WinDbg 說話。

一:背景

1.講故事

前段時間有位朋友在微信上找到我,說他對一個商業的 C# 程序用 WinDbg 附加不上去,每次附加之后那個 C# 程序就自動退出了,問一下到底是怎么回事?是不是哪里搞錯了,有經驗的朋友應該知道,其實這是 商業程序 的反調試機制搗鬼的,為了保護程序隱私,一般都不希望他人對自己做逆向分析,那能不能破解它的反調試呢?當然是可以的,難易程度就看對方的誠意了。

經過和朋友的技術搗鼓之后,發現還好,對方只是用了 KERNELBASE!IsDebuggerPresent 做的反調試判斷,難度不大,這里就不細聊那個程序,我們做一個簡單的案例來說下如何反反調試,老規矩,上 WinDbg 說話。

二:WinDbg 分析

1. 案例演示

為了方便講述,先上一個例子。

internal class Program
    {
        [DllImport("kernelbase.dll", SetLastError = true)]
        static extern bool IsDebuggerPresent();

        static void Main(string[] args)
        {
            Console.ReadLine();

            var isAttached = IsDebuggerPresent();

            if (isAttached)
            {
                Console.WriteLine("/(ㄒoㄒ)/~~ 小心,我被附加了 調試器!");
            }
            else
            {
                Console.WriteLine("O(∩_∩)O 程序很安全!");
            }

            Console.ReadLine();
        }
    }

在沒有 WinDbg 的情況下是這樣輸出的。

圖片圖片

有 WinDbg 的情況下是這樣輸出的。

圖片圖片

有朋友肯定要懟了,C# 中有一個 Debugger.IsAttached 屬性為什么不用,我試了下,這玩意很差勁,檢測不到 WinDbg 這種非托管調試器的附加。

2. 簡述 IsDebuggerPresent 方法

其實 IsDebuggerPresent 方法提取的是 PEB 中的 BeingDebugged 字段,這個字段定義在 KernelBase.dll 中,那怎么驗證呢? 可以用 !peb 查看進程環境塊的地址,然后用 dt 觀察即可。

0:001> !peb
PEB at 000000000035b000
    InheritedAddressSpace:    No
    ReadImageFileExecOptions: No
    BeingDebugged:            Yes
    ImageBaseAddress:         00007ff719030000
    NtGlobalFlag:             4000
    NtGlobalFlag2:            0
    Ldr                       00007ffb1259b4c0
    ...

0:001> dt ntdll!_PEB 000000000035b000
   +0x000 InheritedAddressSpace : 0 ''
   +0x001 ReadImageFileExecOptions : 0 ''
   +0x002 BeingDebugged    : 0x1 ''
   +0x003 BitField         : 0x4 ''
   +0x003 ImageUsesLargePages : 0y0
   +0x003 IsProtectedProcess : 0y0
   +0x003 IsImageDynamicallyRelocated : 0y1
   +0x003 SkipPatchingUser32Forwarders : 0y0
   ...

從上面的 BeingDebugged : 0x1 可以看到,當前程序被附加了調試器。

3. 反反調試思路

找到 IsDebuggerPresent() 方法的讀取來源,這問題就好辦了,通常有兩種做法。

1)修改 IsDebuggerPresent() 方法的反匯編代碼

只要讓 IsDebuggerPresent() 方法一直返回 false,那我們就可以成功破解反調試,首先用 x 命令找到 IsDebuggerPresent() 的匯編代碼,輸出如下:

0:007> x KernelBase!IsDebuggerPresent
00007ffb`0fe468a0 KERNELBASE!IsDebuggerPresent (IsDebuggerPresent)
0:007> u 00007ffb`0fe468a0
KERNELBASE!IsDebuggerPresent:
00007ffb`0fe468a0 65488b042560000000 mov   rax,qword ptr gs:[60h]
00007ffb`0fe468a9 0fb64002        movzx   eax,byte ptr [rax+2]
00007ffb`0fe468ad c3              ret
00007ffb`0fe468ae cc              int     3
00007ffb`0fe468af cc              int     3
00007ffb`0fe468b0 cc              int     3
00007ffb`0fe468b1 cc              int     3
00007ffb`0fe468b2 cc              int     3

按照 stdcall 協定, eax 會作為方法的返回值,接下來使用 WinDbg 的 a 命令修改 00007ffb0fe468a0 處的匯編代碼,鍵入完匯編代碼之后,按 Enter 即可,輸出如下:

0:007> a 00007ffb`0fe468a0
00007ffb`0fe468a0 mov eax , 0
00007ffb`0fe468a5 ret 
00007ffb`0fe468a6 

0:007> u 00007ffb`0fe468a0
KERNELBASE!IsDebuggerPresent:
00007ffb`0fe468a0 b800000000      mov     eax,0
00007ffb`0fe468a5 c3              ret
00007ffb`0fe468a6 0000            add     byte ptr [rax],al
00007ffb`0fe468a8 000f            add     byte ptr [rdi],cl
00007ffb`0fe468aa b640            mov     dh,40h
00007ffb`0fe468ac 02c3            add     al,bl
00007ffb`0fe468ae cc              int     3
00007ffb`0fe468af cc              int     3

圖片圖片

可以看到 WinDbg 已成功修改了 KERNELBASE!IsDebuggerPresent 方法的代碼,哈哈,接下來繼續 go,截圖如下:

圖片圖片

可以看到已成功的反反調試,看到程序很開心,我也挺開心的。

2)使用bp斷點攔截

這種做法就是使用 bp + script 攔截,大概就是在 KERNELBASE!IsDebuggerPresent的ret 處用腳本自動修改 eax 值,這也是可以的,當然也是最安全的。

首先觀察一下 uf KERNELBASE!IsDebuggerPresent 函數的匯編代碼。

0:004> uf KERNELBASE!IsDebuggerPresent
KERNELBASE!IsDebuggerPresent:
00007ffb`0fe468a0 65488b042560000000 mov   rax,qword ptr gs:[60h]
00007ffb`0fe468a9 0fb64002        movzx   eax,byte ptr [rax+2]
00007ffb`0fe468ad c3              ret

接下來在 00007ffb0fe468ad 處下一個斷點,即位置 KERNELBASE!IsDebuggerPresent + 0xd ,然后使用寄存器修改命令 r 修改 eax 的值,再讓程序 gc 即可,腳本代碼如下:

0:004> bp KERNELBASE!IsDebuggerPresent+0xd "r eax =0; gc"
0:004> g

圖片圖片

可以看到,此時的程序又是笑哈哈的。

三:總結

這篇文章無意對抗,只是對一個疑難問題尋求解決方案的探索,大家合理使用。

責任編輯:武曉燕 來源: 一線碼農聊技術
相關推薦

2022-11-02 08:51:01

2024-12-26 10:05:58

C#前臺線程

2024-08-26 14:46:57

2021-03-29 00:02:10

C#Attribute元素

2024-06-28 12:47:29

C#弱引用底層

2022-08-30 07:39:57

C++namespace隔離

2020-10-30 07:11:31

C 語言編程

2023-05-04 12:39:27

GDB命令程序

2023-07-03 07:27:41

進程線程Win32

2020-12-09 16:55:57

程序員技術

2020-10-23 07:00:00

C++函數

2023-07-06 13:56:14

微軟Skype

2024-01-02 13:26:39

TLSC#線程

2025-01-10 08:15:22

C#異步底層

2023-12-14 11:35:32

.NET泄露模式

2020-09-08 06:54:29

Java Gradle語言

2021-01-28 22:31:33

分組密碼算法

2023-09-22 17:36:37

2020-05-22 08:16:07

PONGPONXG-PON

2018-06-07 13:17:12

契約測試單元測試API測試
點贊
收藏

51CTO技術棧公眾號

国产伦精品一区二区三区视频痴汉 | 欧美成人一区二区在线观看| 五月婷婷久久久| 久久蜜桃精品| 久久99精品久久久久久青青91| yjizz视频| 成人在线免费av| 亚洲影院免费观看| 日本不卡一区二区三区在线观看 | 日韩三级电影网址| 乱子伦视频在线看| 少女频道在线观看免费播放电视剧| 91最新地址在线播放| 国产精品高潮呻吟久久av野狼| 国产黄色片在线免费观看| 自拍偷拍精品| 亚洲精品在线三区| www.cao超碰| 日本久久免费| 亚洲成人中文在线| 色乱码一区二区三区熟女| 亚洲 另类 春色 国产| 韩国成人精品a∨在线观看| 日韩免费在线看| 国产大片中文字幕在线观看| 日韩欧美三级| 亚洲视频国产视频| a天堂视频在线观看| 爱情电影网av一区二区| 在线视频国内自拍亚洲视频| 午夜免费福利小电影| 成人在线直播| 国产精品不卡在线| 日韩免费毛片| 男人av在线| 97久久超碰精品国产| 91黄在线观看| 国产伦理一区二区| 蜜桃91丨九色丨蝌蚪91桃色| 日本欧美一级片| 天堂网av手机版| 激情婷婷久久| 久久久久久久影院| 久草网视频在线观看| 一本精品一区二区三区| 久久久成人av| 婷婷伊人五月天| 91精品精品| 久久久精品视频成人| 小向美奈子av| 四虎成人av| 精品国产一区二区三区久久久| 国产精品久久久视频| 欧美精选视频在线观看| 亚洲新中文字幕| 一道本在线观看| 加勒比久久综合| 在线免费看av不卡| 中文字幕91视频| 三区四区不卡| 久久不射电影网| 久久久91视频| 亚洲精品色图| 人妖精品videosex性欧美| 男人天堂2024| 老司机午夜精品| 成人国产在线视频| 成人av无码一区二区三区| 成人一区二区在线观看| 久久精品一区二区三区不卡免费视频| 天堂在线资源网| 久久网这里都是精品| 色爱区成人综合网| 九七久久人人| 亚洲五月六月丁香激情| 日韩精品一区二区三区久久| 成人黄色免费网站| 欧美一区二区福利在线| 欧美成人精品一区二区综合免费| 欧美综合自拍| 中文字幕日韩在线观看| 加勒比av在线播放| 首页欧美精品中文字幕| 91精品国产综合久久香蕉| 精品久久久久中文慕人妻| av亚洲精华国产精华| 日韩电影在线播放| 伊人福利在线| 色婷婷综合在线| 奇米777在线视频| 欧美调教在线| 久久精品国产2020观看福利| 日本熟伦人妇xxxx| 免费久久精品视频| 国产伦精品一区二区三毛| 国产一区精品| 亚洲一区二区欧美| 在线观看免费成人av| 婷婷综合国产| 伊人av综合网| 日韩三级一区二区三区| 九一九一国产精品| 久久国产精品 国产精品| 麻豆影院在线| 日韩欧美亚洲国产一区| 激情久久综合网| 国产麻豆一区二区三区精品视频| 美日韩精品免费视频| 中文字幕手机在线视频| 成人黄色小视频在线观看| 亚洲v国产v| gay欧美网站| 欧美zozozo| 91麻豆精品成人一区二区| 国产精品毛片一区二区三区| 亚洲在线免费观看| a√资源在线| 欧美日韩综合视频| 91小视频在线播放| 欧美日韩黑人| 国产成人短视频| 色婷婷视频在线| 一区二区高清视频在线观看| 一级在线免费视频| 九热爱视频精品视频| 97视频免费看| 国产91久久久| 一区二区三区精密机械公司| 亚洲免费av一区| 日韩精品一卡| 国产精品免费久久久久久| 日本视频在线观看一区二区三区 | 五月天婷婷综合网| 国产精品夜夜嗨| 日韩第一页在线观看| 91在线亚洲| 亚洲网址你懂得| 欧美一级淫片免费视频黄| 99久久精品国产一区二区三区 | 欧美xxx黑人xxx水蜜桃| 4438x亚洲最大成人网| 人妻无码一区二区三区免费| 玖玖国产精品视频| 日韩福利视频| 在线成人视屏| 中文欧美在线视频| 最近国语视频在线观看免费播放| 久久综合色天天久久综合图片| 国产在线播放观看| 天美av一区二区三区久久| 午夜精品久久久久久久99热 | 久久精品无码av| 91免费小视频| 91av俱乐部| 秋霞欧美视频| 成人免费xxxxx在线观看| 免费a级毛片在线播放| 欧美老人xxxx18| 污软件在线观看| 国产一区91精品张津瑜| 免费极品av一视觉盛宴| 超碰成人福利| 日本精品在线视频 | 中文字幕电影一区| 91亚洲免费视频| 亚洲精品一区二区在线看| 亚洲aⅴ男人的天堂在线观看| 伊人精品影院| 日韩精品极品视频免费观看| 亚洲成熟少妇视频在线观看| 中文av字幕一区| 中文字幕乱码在线人视频| 在线播放日韩| 日韩免费三级| 欧美激情三级| 97在线视频免费播放| 国产在线资源| 日韩三级视频在线看| 日韩一区二区视频在线| 中文字幕欧美区| 亚洲欧美激情一区二区三区| 国产欧美日韩综合一区在线播放 | 国产精品无av码在线观看| 性欧美ⅴideo另类hd| 日韩国产精品一区| 一二三区中文字幕| 亚洲 欧美综合在线网络| 法国空姐电影在线观看| 精品一区二区三区不卡| 国产欧美日韩网站| 99久久久久| 久久伦理网站| 精品一区二区三区四区五区 | 日韩黄色三级在线观看| 韩日精品中文字幕| 欧美激情午夜| 日韩精品欧美激情| 国产精品无码在线播放| 日韩欧亚中文在线| 国产av 一区二区三区| 91在线播放网址| 加勒比av中文字幕| 亚洲欧美激情诱惑| 欧洲精品视频在线| 不卡中文字幕| 精品亚洲一区二区三区四区五区高| 欧美激情福利| 奇米四色中文综合久久| 在线观看三级视频| 中文字幕亚洲在线| 爽爽视频在线观看| 精品对白一区国产伦| 国产精品乱码一区二区| 在线国产电影不卡| 五月激情六月丁香| 亚洲国产精品精华液网站| 欧洲美女女同性互添| 久久久99久久| 国产精品揄拍100视频| 国产成人av一区二区三区在线| 在线观看亚洲色图| 久久久亚洲人| 97在线播放视频| 一区二区日韩免费看| www成人免费| 欧美一区高清| 亚洲小说欧美另类激情| 日韩黄色大片| 亚洲精品在线免费看| 国产传媒欧美日韩成人精品大片| 国产日韩一区欧美| 福利片一区二区| 97在线电影| 视频精品二区| 91在线直播亚洲| 高清久久精品| 91视频国产精品| 国产精品1区| 成人字幕网zmw| 国产日韩中文在线中文字幕| 成人xxxxx| av一级久久| 亚洲japanese制服美女| 999色成人| 亚洲最大av在线| 日韩精品久久久久久久软件91| 91最新在线免费观看| 欧美电影院免费观看| 99久久精品免费看国产一区二区三区| 永久免费观看精品视频| 91系列在线播放| 日韩中文字幕在线一区| yy111111少妇影院日韩夜片 | 久久电影网站中文字幕| 在线黄色免费看| 国产精品1区2区| 老熟女高潮一区二区三区| 国产91精品在线观看| 在线xxxxx| 久久综合色一综合色88| 国产欧美小视频| 综合分类小说区另类春色亚洲小说欧美| 国产美女高潮视频| 一区二区三区欧美久久| 日韩经典在线观看| 色偷偷成人一区二区三区91| 在线观看xxxx| 精品国产三级a在线观看| 亚洲av成人精品毛片| 在线观看欧美日韩| 18视频在线观看网站| 91精品国产高清| 免费污视频在线一区| 91精品中文在线| 精品亚洲免a| 天堂社区 天堂综合网 天堂资源最新版| 日韩中文字幕高清在线观看| 成人免费网站入口| 亚洲另类视频| 四季av一区二区| 懂色av噜噜一区二区三区av| 女人又爽又黄免费女仆| 亚洲视频一二三| 五月天综合激情网| 欧美夫妻性生活| 日中文字幕在线| 久久久999精品免费| 性欧美18~19sex高清播放| 成人激情在线播放| 中文字幕精品影院| 黄色片免费在线观看视频| 日韩精品1区2区3区| 潘金莲一级淫片aaaaa| 国产欧美一区二区在线| 久久久精品人妻一区二区三区四 | 亚洲丝袜自拍清纯另类| 日韩字幕在线观看| 7777精品久久久大香线蕉| 无码精品人妻一区二区三区影院| 神马久久桃色视频| 韩国美女久久| 成人黄色在线免费观看| 日本黄色精品| 日韩a在线播放| 成人av免费网站| 91麻豆精品成人一区二区| 欧美在线一区二区| 天天综合网在线观看| 欧美成人午夜视频| 岛国精品在线| 欧美视频观看一区| 亚洲黄色高清| 国产精品嫩草69影院| 中文字幕亚洲一区二区va在线| 在线能看的av| 亚洲国产91色在线| 青草视频在线免费直播| 92福利视频午夜1000合集在线观看| 不卡日本视频| 国产v亚洲v天堂无码久久久| 99国产精品久久久久久久久久久| 一区二区三区四区五区| 欧美日韩高清在线播放| 精彩国产在线| 欧美中文在线观看国产| 国产精品对白久久久久粗| 亚洲色婷婷久久精品av蜜桃| 九九**精品视频免费播放| 亚洲色图 激情小说| 欧洲精品在线观看| 国产在线一二三| 国产成人精品久久二区二区91| 天堂成人娱乐在线视频免费播放网站 | 亚洲区 欧美区| 亚洲综合一区二区| 精品黑人一区二区三区在线观看| 久久亚洲国产精品| 亚洲欧美在线人成swag| 欧美性受黑人性爽| 国产专区欧美精品| 国产成人无码aa精品一区| 91精品国产免费| 99视频免费在线观看| 18成人在线| 欧美日韩成人| 亚洲日本久久久| 精品国产成人av| 色视频精品视频在线观看| 欧美一级淫片videoshd| 制服丝袜日韩| 天天干天天干天天干天天干天天干| 国产免费久久精品| 国产在成人精品线拍偷自揄拍| 久久深夜福利免费观看| 国产一区二区三区免费在线 | 视频精品一区二区| 人妻熟人中文字幕一区二区| 欧美日韩一区二区欧美激情| 欧美激情视频在线播放| av一本久道久久波多野结衣| 亚洲黄页一区| 日韩人妻无码精品综合区| 欧美日韩在线三级| 在线观看男女av免费网址| 国内精品视频在线播放| 日本欧美一区二区三区乱码| 国产又粗又硬又长又爽| 亚洲精品在线观| 精品无人乱码一区二区三区| 正在播放91九色| 成人免费视频视频| 国产午夜无码视频在线观看| 日韩有码在线电影| japanese色系久久精品| 无码内射中文字幕岛国片| 亚洲免费观看高清完整版在线观看| 免费国产精品视频| 国产精品jizz在线观看麻豆| 亚洲女同另类| 国产熟妇久久777777| 制服丝袜成人动漫| 性欧美18~19sex高清播放| 一本一道久久a久久精品综合| 福利电影一区二区| 午夜一区二区三区四区| 欧美大片免费观看| 国内成人自拍| 99国产精品免费视频| 日本高清不卡视频| 欧美韩日亚洲| 先锋在线资源一区二区三区| 成人一级视频在线观看| 伊人精品在线视频| 97超级碰在线看视频免费在线看| 日韩理论电影大全| 精品中文字幕在线播放| 7878成人国产在线观看| 成人教育av| www精品久久| 亚洲私人影院在线观看|