日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

.Net JIT騷操逆向最新版Dngurad HVM

來源: 責(zé)編: 時間:2023-10-27 17:20:40 390觀看
導(dǎo)讀前言Dnguard HVM(以下簡稱DHVM),它通過對虛擬機(jī)(CLR)和JIT加密,號稱.Net最強(qiáng)加密軟件。截至10月27日目前官網(wǎng)最新版4.60版,它的試用版可以下載試用,本篇看下它這個最新版的強(qiáng)度。2.概述本篇看下它的新版改動了哪些東西,加

前言

Dnguard HVM(以下簡稱DHVM),它通過對虛擬機(jī)(CLR)和JIT加密,號稱.Net最強(qiáng)加密軟件。截至10月27日目前官網(wǎng)最新版4.60版,它的試用版可以下載試用,本篇看下它這個最新版的強(qiáng)度。xhU28資訊網(wǎng)——每日最新資訊28at.com

2.概述

本篇看下它的新版改動了哪些東西,加固了加密程度。xhU28資訊網(wǎng)——每日最新資訊28at.com

調(diào)用托管Main:xhU28資訊網(wǎng)——每日最新資訊28at.com

threadStart.Call(&stackVar);

之后JIT編譯函數(shù)invokeCompileMethod的methodInfo參數(shù)的成員變量ILCode處的情況。xhU28資訊網(wǎng)——每日最新資訊28at.com

000000018047407E 41 D2 E3             shl         r11b,cl0000000180474081 41 D3 F3             sal         r11d,cl0000000180474084 45 0F C1 DB          xadd        r11d,r11d0000000180474088 4C 8B 5E 10          mov         r11,qword ptr [rsi+10h]000000018047408C 4C 89 5F 10          mov         qword ptr [rdi+10h],r11

老板的情況:xhU28資訊網(wǎng)——每日最新資訊28at.com

0000000180497AB2: E9 A1 73 00 00 jmp  0000000180497AB80000000180497AB7: F8             clc0000000180497AB8: 4C 89 5F 10    mov  qword ptr [rdi+10h],r11

r11寄存器做了一些位移和相加的動作,應(yīng)該是解密ILCode的地址和確保r11不能修改,可見它確實做了加固加密處理。此外,在經(jīng)過試驗,在Jmp指令跳轉(zhuǎn)到指定的位置時,會出現(xiàn)與HVMRun64.dll二進(jìn)制不符合的數(shù)據(jù)。這應(yīng)該也是它的一個反破解機(jī)制。xhU28資訊網(wǎng)——每日最新資訊28at.com

這兩個東西,加上去似乎增加了難度。這種方式加上之前的防御策略,確實能阻擋大部分人。然二進(jìn)制無不可做之事。我們順著這個地址(000000018047408C)往下看:xhU28資訊網(wǎng)——每日最新資訊28at.com

000000018047409D 0F 84 DD 00 00 00 je 0000000180474180

這個地方其實可以hook下,但是DHVM似乎進(jìn)行了相應(yīng)的反hook機(jī)制,所以無法做到,繼續(xù)往下看。xhU28資訊網(wǎng)——每日最新資訊28at.com

00000001804741C7 E9 00 00 00 00          jmp         00000001804741CC00000001804741CC C6 84 24 81 00 00 00 2A  mov         byte ptr [rsp+81h],2Ah00000001804741D4 E9 00 00 00 00          jmp         00000001804741D900000001804741D9 E8 C2 82 BA FF          call        000000018001C4A0

這兩個jmp都是跳轉(zhuǎn)到j(luò)mp本身指令集的下一條指令集地址的特性。所以這里是hook的好地方:xhU28資訊網(wǎng)——每日最新資訊28at.com

以上代碼可以改為:xhU28資訊網(wǎng)——每日最新資訊28at.com

00000001804741C7 4C 8B 6F 10          mov         r13,qword ptr [rdi+10h]00000001804741CB 90                   nop00000001804741CC C6 84 24 81 00 00 00 2A mov         byte ptr [rsp+81h],2Ah00000001804741D4 49 C6 45 0D 08       mov         byte ptr [r13+0Dh],800000001804741D9 E8 C2 82 BA FF       call        000000018001C4A0

如此跳轉(zhuǎn)實際上是廢跳,原理是把利用這兩個jmp的特性,對它進(jìn)行了一個Hook。xhU28資訊網(wǎng)——每日最新資訊28at.com

把ILCode的地址也即是【rdi+0x10】的地址賦給r13,然后把r13偏移量為0XD的地方byte修改為8.xhU28資訊網(wǎng)——每日最新資訊28at.com

它的一個C#示例是:xhU28資訊網(wǎng)——每日最新資訊28at.com

static void ABC(){    Console.WriteLine("Call ABC");}static void DEF(){    Console.WriteLine("Call DEF");}static void Main(string[] args){   Console.WriteLine("Call Main");   ABC();   DEF();   Console.ReadLine();}

Main里面調(diào)用了函數(shù)ABC和DEFxhU28資訊網(wǎng)——每日最新資訊28at.com

調(diào)用ABC和DEF的二進(jìn)制MSIL分別為:xhU28資訊網(wǎng)——每日最新資訊28at.com

ABC:28 07 00 00 06 00DEF:28 08 00 00 06 00

他們不同點事,07和08,調(diào)用ABC的二進(jìn)制MSIL在整個ILCode里面的偏移是0xD。所以上面Hook代碼xhU28資訊網(wǎng)——每日最新資訊28at.com

00000001804741D4 49 C6 45 0D 08  mov  byte ptr [r13+0Dh],8

本來它的調(diào)用打印的結(jié)果是:xhU28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片xhU28資訊網(wǎng)——每日最新資訊28at.com

hook之后打印的結(jié)果是:xhU28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片xhU28資訊網(wǎng)——每日最新資訊28at.com

3.結(jié)尾

DHVM新版加強(qiáng)了難度,但我們可以利用指令集的一些特性來對它進(jìn)行學(xué)習(xí)和研究,依然非常簡單。xhU28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-15432-0.html.Net JIT騷操逆向最新版Dngurad HVM

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Next.js 14 正式發(fā)布,更快、更強(qiáng)、更可靠!

下一篇: 事與愿違:可變類出現(xiàn)了線程安全問題

標(biāo)簽:
  • 熱門焦點
Top 主站蜘蛛池模板: 齐齐哈尔市| 鹤庆县| 镇康县| 驻马店市| 育儿| 咸宁市| 云梦县| 万山特区| 罗田县| 霞浦县| 叶城县| 江华| 和平县| 武汉市| 汶川县| 阜平县| 扶沟县| 巴楚县| 东乌珠穆沁旗| 若尔盖县| 繁昌县| 华蓥市| 海林市| 望江县| 曲松县| 台东县| 浮山县| 都安| 顺昌县| 辽宁省| 唐河县| 安达市| 漳平市| 盐池县| 长岭县| 筠连县| 年辖:市辖区| 通海县| 宁化县| 林口县| 郓城县|