NET项目反编译+VS解决方案整理流程

时间:2021-09-14 08:59:11

net项目反编译

工具:De4Dot + IL SPY和Reflector结合使用

项目:vs10+创建解决方案,每个类库尽量按照dll名来命名,方便整合,新建web项目先把aspx等文件拷贝进去,注意:bin文件夹不用拷贝

一、没有混淆的代码

1.IL SPY反编译出来的代码相对干净

2.Reflector反编译代码里面容易出现goto等结构可读性差,还会加入较多的乱码代码

建议:IL SPY导出代码,往vs项目里拷贝,生成项目时报错文件可与Reflector反编译文件对比,方便排查错误。

二、有混淆的代码

先使用De4Dot进行反混淆,反混淆出来的dll在用IL SPY或Reflector进行反编译

  反混淆步骤:

  1.1打开 De4Dot 所在文件夹,按住 Shift,右键该文件夹 → 选择“在此处打开命令窗口”也可以打开“命令提示符”,再定位到 De4Dot 所在目录。

  1.2输入 De4Dot + 要反混淆 .net 文件,如输入 De4Dot G:\xx\xx.dll 回车,反混淆成功,在 G:\xx\目录下生成一个反混淆后的 xx-cleaned.dll 文件。

  1.3用 IL SPY或Reactor 打开 xx-cleaned.dll 文件源代码定义的变量和方法已经显示出来,说明反混淆成功。

三、项目整理

1.vs创建好类库项目已经web项目,根据各dll层级管理添加好项目引用,第三方dll放专门文件夹里,防止丢失方便查找引用。

2.混淆导出的代码拷贝到对应的类库,如:三层代码,先拷贝Model然后DAL最后BLL,拷贝完成一项生成对应类库(或生成解决方案,防止错误代码太多)

3.所有类库代码处理完成之后处理最为复杂的web项目里的反编译代码

  3.1、反编译出来的代码后缀为.cs,而项目里需要的文件是.aspx.cs,否则项目里的aspx文件与反编译出来的文件关联不起来

  3.2、批量替换文件名;在当前这个文件夹下面,先新建一个记事本,改后缀为bat,编辑ren *.cs  *.aspx.cs(注意*号前面为英文半角空格),保存后双击执行;在目录空白处右键刷新查看是否已经修改过来。

      如果替换错了(独立的类不要替换为aspx.cs)想要恢复.cs新建另一个bat文件内容填写

      @echo off
      Setlocal Enabledelayedexpansion
      set "str=.aspx"
      for /f "delims=" %%i in ('dir /b *.cs') do (
      set "var=%%i" & ren "%%i" "!var:%str%=!")

  温馨提醒:批量替换哪个文件夹下面的文件,就在对应文件夹根目录创建对应的bat文件(多个文件夹多个bat),跨文件夹批量替换暂未找到合适的方法,有熟悉的请告知,谢谢。

  3.3、把替换过的文件拷贝到web文件夹下(注意不要直接拖拽到vs里),切换到vs右键包含在项目中,aspx和aspx.cs文件就会自动关联;如果aspx文件与反编译出来的文件没有关联,排查aspx里的Codebehind和Inherits设置是否正确aspx.cs里命名空间,类名是否正确等,确保没有问题先把aspx和aspx.cs文件排除项目,在右键包含在项目中,一般情况下vs会自动把两个文件关联在一起。

  3.4、包含在项目中分批包含,等把错误提示都排查完,整个项目从反编译到项目整理基本也就完成了

四、记录

1.反编译需要耐心,要一点点排错,越复杂的项目越需要一步步处理,毕竟反编译完就可以用的项目很少。

2.多学习Reflector反编译,毕竟是用的比较多的,各搜索引擎解决方案文档等较全面

五、针对dll里想要修改部分代码直接再生成新的dll,这样的工具还没有找合适的,如果有熟悉的朋友,望留言告知。