zoukankan      html  css  js  c++  java
  • NET项目反编译+VS解决方案整理流程

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

    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,这样的工具还没有找合适的,如果有熟悉的朋友,望留言告知。

    作者:郑州 - 在路上

    出处:http://www.cnblogs.com/oorz/

    Q群:NET CORE技术交流(444036561)NET CORE技术交流

    微信公众号:“专卓”;因为专业,所以卓越!可扫描左侧二维码关注。

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

    分类: NET环境

  • 相关阅读:
    python获取指定日期和转换的整理
    调用baidu地图API,实现语音导航播报
    Quartus 调试笔记
    mybatis-plus学习遇到的坑
    X509Certificate
    Hyperledger Fabric学习笔记——Wallet
    [WCF权限控制]从两个重要的概念谈起:Identity与Principal
    9-HyperLedger-Fabric原理-MSP详解(一)-MSP基础
    区块链中的“双花”问题
    区块链共识算法 PBFT(拜占庭容错)、PAXOS、RAFT简述
  • 原文地址:https://www.cnblogs.com/grj001/p/12224800.html
Copyright © 2011-2022 走看看