首页
社区
课程
招聘
如果你不懂.net逆向,又对它感兴趣,请进!(修正版)
发表于: 2006-8-29 00:21 32725

如果你不懂.net逆向,又对它感兴趣,请进!(修正版)

2006-8-29 00:21
32725

先声明,偶既不是专业程序员,从事的工作也和IT毫无关系,只是有兴趣时就看一点逆向的东东,纯粹是当游戏。所以各位大牛不用以专业的眼光来审视偶写的文章及偶做的工作。偶接触.net可能比某些新手早些,为了让对.net逆向有兴趣的朋友少走弯路,特写此文。

1、从哪儿着手
    要想逆,首先对写程序多少要有点了解。因此,偶觉得掌握一门高级的.net编程语言是必须的,一般都是C#、VC.net或VB.net。不必程序编得很好,但至少流程要看得懂吧。这类书很多,找本入门的看看既可。然后,就得了解.net运行的基本机制了,类似于win32下ring3层必须要了解线程啊、进程啊、断点啊之类的,.net下也必须了解一些最基本的运行机制。(后面还要介绍一些更底层的机制,类似于win32下的rootkit,属于.net中的ring0)。
    就像win32下逆向要学asm一样,.net下也必须掌握MSIL,这是.net下的汇编语言。与asm比起来,IL的语法简单的多,会很快掌握的。还有一个很重要的,就是.net下PE的结构。这里讲的PE结构,和win32下也不同,指的是一种叫元数
据的结构(Metadata),.net下程序集的信息都以各种形式的Metadata存储在文件中。了解了元数据的结构,对于了解.net下的各种运行机制(比如名称混淆)都很有帮助。
    下面给出几本资料,有的有中文译本,但毕竟.net是人家微软的东东,所以还是英文资料多(网上均可下)。不要求每本看完,但求用时有地方查:


Applied Microsoft .NET Framework Programming(Microsoft Press)


Inside Microsoft .NET IL Assembler (Microsoft Press)


.Net Framework Essentials(O'Reilly)


The Common Language Infrastructure Annotated Standard(Addison Wesley)


Understanding .NET, Second Edition(Addison Wesley)

2、用哪些工具
    如果上面书都看完了(不会吧,你全都看完了?天才啊!),下面开始动手了。搞破解逆向玩儿的谁没几个用得得心应手的工具。下面我按分类列一些我用的多点的工具,不求全,但求精。

2.1 程序设计
    最好用的就是VS.net 2003和2005了,配合上VisualAssist,程序设计就不愁了。买(或D)一个VS套装,里面包含了.Net SDK和VS的IDE。

2.2 编译
    当然,如果是只有几行代码的小程序,C#的便可以用CSC.exe编译,IL代码的可以直接用ILASM编译。

2.3 反编译
    这是逆向中最基本也可以说是最重要的一环,微软的东东往往是最基本也最不可或缺少的,SDK中自带的ildasm.exe。
    再就是一些第三方开发的反编译软件,最好用的莫过于Reflector(能在PEDIY里搜到的就不再贴链接了),当然,也因为它被使用的最广,现在越来越多anti的手段了,但仍是必不可少。

    Decompiler .Net 2005是另一个功能比较强的软件,但偶用的不多。还有就是Xenocode Fox。IDApro在win32是相当好用,可惜在.net下其应用性实在是大打折扣。

2.4 调试
    调试一直是.net下的弱项。其实不是弱,只是比起win32下起来,用户可做的感觉没那么多,没那么底层,操作习惯也是大有改变。
    如果编程中的调试,用VS.net自带的调试功能既可,非常方便的。
    对于无源码的程序要调试,可以用ildasm反汇编至il,再带/debug编译成exe文件,这样可以用SDK安装目录下的GuiDBG进行调试。不过现在这种可能性越来越少,比如最简单的混淆成不可见字符的.net程序集,在编译回去时会报错。
    如果直接调试,偶知道的目前唯一好用的就是PEBrowse的软件。关于它的使用坛里有文章,对于大多数.net程序确实是一把利剑,强烈推荐大家使用。

    我没说Ollydbg和Windbg不能用啊,只是调试起来不是很直观,不太方便。但仍有不少好例子,比如Flier大牛写的《用WinDbg探索CLR世界》,对.net不是了解到一定层次是写不出这种文章的。

2.5 混淆与反混淆
    混淆的东西太多,只举几个有代表性的。偶知道的第一个混淆器就是VS.net自带的Dotfuscator的演示版,只是将有意义的字符变为几个简短的数字,谈不上什么强度。
    另一个比较有名的就是Xenocode的混淆,文件名变为长长的字母加数字。不过说实话,这样搞还不如前面说的混淆成简短数字来的有效。但是它还有一个功能就是流程混淆(好像是它的功能,没有验证),类似于win32下的花指令,并且这种方法是对付Reflector静态反编译的有效利器。
    再就是Spices.net出的混淆器了,将字符串加密为不可见字符,在Reflector里看到的都是方框。这种相对恼火一些,但这种混淆再强,只要花了足够的时间,总是可以找到关键的代码的。

2.6 加壳
    加壳是win32下很普遍的做法了,但在.net下还不是很多。同样,分两种,压缩壳和加密壳。压缩壳不多说了,只说加密壳。比较好的是MaxtoCode和Remotesoft Protector,这两个壳相当于在.net和windows中添加了个过滤层,将源代码加密存储,动态解密执行,现在还没有较好的方法应付,也或者是有了但没公开。(当然,除了JasonNET大牛了,呵呵)

    提一下,为什么很多dump软件对加密过的.net程序不起作用,比如MaxtoCode。因为.net的程序是按方法既时在内存中编译的,再加上垃圾收集机制,所以任何时候在内存中通常不会出现完整的原程序。即使有,也可以将其代码加密,dump下来也是没法阅读的。

3   .net的核心
    这里讲讲前文提到的.net下的ring0,说白了三大块,Profiler、Debugger和Metadata。当你爆破过N个程序后,会感觉到止步不前,这时你就要考虑下看看更深层次的东西了。这些文档在.Net v1.1中的目录是\Microsoft.NET\SDK\v1.1\Tool Developers Guide\docs,V2.0的文档已经被移到MSDN了。不过微软的开发手册更适合当资料查,还是看一些tutorial入门快些。这里给出一些文献,全都在MSDN中和google中可以搜到,大家一同学吧。虽然如lccracker所说,是别人数年前的东西,但还是得看啊(加红色为我已看过并强力推荐先阅读的):

dotNET Internals The Profiling API

Drill Into .NET Framework Internals to See How the CLR Creates Runtime Objects

Examine Running Processes Using Both Managed and Unmanaged Code

Improve Your Understanding of .NET Internals by Building a Debugger for Managed Code

Rewrite MSIL Code on the Fly with the .NET Framework Profiling API

The .NET Profiling API and the DNProfiler Tool

Tracing APIs in .NET Framework 2.0

Write Profilers With Ease Using High-Level Wrapper Classes

在 .NET Framework 2.0 中,没有任何代码能够逃避 Profiling API 的分析

使用 .NET Profiler API 检查并优化程序的内存使用

.NET Framework Developer Center CLR Run-Time Breaking Changes

Modifying IL at runtime

An Overview of Managed Unmanaged Code Interoperability

Build a Logging and Event Viewing Library to Help Debug Your .NET Framework based App

Taming the CLR: How to Write Real-Time Managed Code

Using the Profiling API Enter/Leave Function Hooks

Writing High-Performance Managed Applications

    debugger方面直接看ref也许不太容易入门,网上有篇非常好的toturial,一步步讲解了debugger的原理和编写,实在是入门的经典《Debuggers under .NET》。
http://blogs.chimpswithkeyboards.com/jonshute/category/2.aspx

    上面这些是文章,还有一本书也涉及到这方面内容,非常值得一看。


Debugging Applications for Microsoft .NET and Microsoft Windows(MS Press)

    微软发布了代号为rotor的shared source cli的源代码,这个对想了解.net核心运行情况是非常有帮助的。其中甚至包括了ilasm、ildasm、一个C#和MSIL的源代码。下载可以去MSDN的网站。关于rotor的资料不多(其实最好的资料就是源代码了),只有两本书,其中一本可以下载到电子版。


    .net Framework最好的讨论去处可能算MSDN Forums了,有两个分论坛不错,一个是Common Language Runtime,另一个是专门讨论debugger的。人气虽然一般,但得到的回答一般是比较权威的。

4  .net破解的层次
    这不是权威的层次划分,纯属搞笑,大家请勿对号入座。
    第一层自然是静态分析加爆破了,用Reflector看程序的源码,搜索关键字符以找到注册码的比较代码,最简单的跳转指令修改,将br.true和br.false互改,这是人生必须经过的阶段。
    第二层,仍是静态分析,但是找到了注册码计算的代码,并且会将这些代码粘贴到自己的程序中,写个小的keygen。
    第三层,能熟练运用动态调试工具对.net程序集进行调试,能下关键的断点,动静结合并更容易的写出注册机(复杂的算法除外)。
    第四层,能更精妙地运用已有的Profiler或Debugger,甚至写个自己的小Profiler或Debugger,在.net的核心层上对程序进行分析。
    第五层,在.net中绝对属于大牛类型,对.net内核极其清楚,能编写程序干预.net与windows的通讯,能将win32的技术运用到.net的保护中,从而破解(或编写)加解密程序。

最后:写这篇文章就像搞逆向破解,反正又不靠它吃饭,纯粹是玩儿。所以你看时也别当真,就当小说吧!.Net下的东西在国外已经研究很多年了,国内也有很多牛人,但明显进度和国外比差了点。没办法,毕竟是人家的东西,所以语言方面国人没有什么优势。因此,要想深入.net核心,掌握英语也是必不可少的!


[培训]内核驱动高级班,冲击BAT一流互联网大厂工作,每周日13:00-18:00直播授课

收藏
免费 7
支持
分享
最新回复 (45)
雪    币: 99672
活跃值: (201129)
能力值: (RANK:10 )
在线值:
发帖
回帖
粉丝
2
sustain.
2006-8-29 00:30
0
雪    币: 85
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
3
顶你啊牛哥~~~~~
2006-8-29 08:34
0
雪    币: 50141
活跃值: (20715)
能力值: (RANK:350 )
在线值:
发帖
回帖
粉丝
4
最初由 tankaiha 发布
如果你不懂.net逆向,又对它感兴趣,请进!(修正版)


谢谢tankaiha为大家接触.net逆向指明了一条学习之路,将帖子标题改了一下,希望本月话题集中讨论一下.net程序的破解与保护。
2006-8-29 09:06
0
雪    币: 339
活跃值: (1510)
能力值: ( LV13,RANK:970 )
在线值:
发帖
回帖
粉丝
5
hmx的文章是一定要来学习的
2006-8-29 09:10
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
6
越来越赶不上形式了呀!
2006-8-29 09:14
0
雪    币: 1022
活跃值: (292)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
7
越来越赶不上形式了呀!
2006-8-29 15:28
0
雪    币: 332
活跃值: (479)
能力值: ( LV9,RANK:330 )
在线值:
发帖
回帖
粉丝
8
虽然不会.net也不想学,但是支持!
2006-8-29 16:25
0
雪    币: 690
活跃值: (1846)
能力值: ( LV9,RANK:250 )
在线值:
发帖
回帖
粉丝
9
有了粗浅的认识,谢谢!
2006-9-1 09:32
0
雪    币: 82
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
10
正在学Inside Microsoft .NET IL Assembler (Microsoft Press),学习.net IL汇编中。
2006-9-1 15:40
0
雪    币: 1634
活跃值: (1392)
能力值: (RANK:50 )
在线值:
发帖
回帖
粉丝
11
tankaiha在dotNet大规模普及之前就准备将来怎么搞定dotNet程序了.
2006-9-1 17:02
0
雪    币: 5275
活跃值: (476)
能力值: (RANK:1170 )
在线值:
发帖
回帖
粉丝
12
晕,其实很多人N年前就搞定了,我已经很迟了.
2006-9-1 21:55
0
雪    币: 203
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
13
请教一下,我有一个软件,用refelector打开后提示“算法操作导致溢出”(大致意思),该怎么办?
2006-9-1 22:11
0
雪    币: 5275
活跃值: (476)
能力值: (RANK:1170 )
在线值:
发帖
回帖
粉丝
14
用ildasm
2006-9-1 23:02
0
雪    币: 338
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
15
强!!一定要收藏!
2006-9-1 23:08
0
雪    币: 191
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
16
写得比较通俗易懂.不错,顶一个
2006-9-2 13:14
0
雪    币: 200
活跃值: (10)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
17
好帖子!。。。
2006-9-2 16:25
0
雪    币: 200
活跃值: (14)
能力值: ( LV2,RANK:10 )
在线值:
发帖
回帖
粉丝
18
写得好,认识到了我在知识上的欠缺,努力学啊
2006-9-2 17:21
0
雪    币: 203
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
19
最初由 tankaiha 发布
用ildasm


用ildasm 也看不到代码,提示说是“***指令解码错误:”
2006-9-2 18:00
0
雪    币: 5275
活跃值: (476)
能力值: (RANK:1170 )
在线值:
发帖
回帖
粉丝
20
呵呵,那就是连ildasm也anti了。
什么程序?
2006-9-2 18:03
0
雪    币: 203
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
21
http://www.3vvv3.com/goldenhelper/tools/GoldenHelper.rar

1.64以前的没有混淆。之后的就有anti了。
不仅ildasm,fox也不行。
2006-9-3 12:08
0
雪    币: 5275
活跃值: (476)
能力值: (RANK:1170 )
在线值:
发帖
回帖
粉丝
22
用的是MaxtoCode加密,好像用的是试用版
搞不定,呵呵
2006-9-3 12:28
0
雪    币: 203
活跃值: (10)
能力值: ( LV4,RANK:50 )
在线值:
发帖
回帖
粉丝
23
最初由 tankaiha 发布
用的是MaxtoCode加密,好像用的是试用版
搞不定,呵呵


没有反maxtocode的工具吗?
我看他有的class没有混淆。
2006-9-9 17:39
0
雪    币: 5275
活跃值: (476)
能力值: (RANK:1170 )
在线值:
发帖
回帖
粉丝
24
MaxtoCode不用混淆的,呵呵
2006-9-9 21:00
0
雪    币: 61
活跃值: (160)
能力值: ( LV9,RANK:170 )
在线值:
发帖
回帖
粉丝
25
2006-9-10 03:33
0
游客
登录 | 注册 方可回帖
返回
// // 统计代码