【转载】教你使用 Reflexil 反编译.NET

【转载】教你使用 Reflexil 反编译.NET

简介

反编译的方式有很多种,其实最靠谱的还是IL反编译。

如果不懂IL可以尝试我这边文章入门:http://www.wxzzz.com/278.html

不过我下面要说的不是IL这种底层的代码反编译,而是Reflector中的Reflexil插件进行反编

也许有人会说Reflector不就是反编译了么,为什么还要用Reflexil这个插件? Reflector 仅仅是反编译出源码给你看,并不能在修改后编译回去。所以我们需要使用Reflexil这个插件进行反编译回去。

.NET 三种反编译方式

这里顺便介绍下我所知道的三种反编译回去的方式:

  1. 直接修改IL代码(当然,这比较难,需要熟悉IL汇编,但是也是最实用的。也许我会在以后的文章详细阐述)
  2. 使用Reflector进行整个代码项目的导出,然后用VS进行修改后编译(在大型项目中,如果有很多其他的dll引用,也许会让你寸步难行,无法使用VS编译通过,所以大型项目直接用IL汇编反编译关键代码即可)
  3. 使用Reflexil插件进行直接反编译(似乎这种要比第二种方法要好的多,至少很省事。其实实际使用起来也不是特别的方便,本文会进行一个稍微详细的使用介绍)

Reflexil 安装

在此之前你需要先去下载Reflector和Reflexil插件,这些你可以去百度或谷歌上面下载到。(如果你不会…那下面的文章不用看了)

下载好之后首先安装Reflector程序,安装完毕后在把Reflexil插件放到Reflector程序目录下面(其实是个dll文件而已),如下图所示

Reflexil_Install

然后打开Reflector,在工具栏依次点击 Tools -> Add-Ins... ,如下图所示

Reflexil_Install2

然后在弹出的界面中点击+号选择刚刚拷贝到Reflector中的Reflexil插件的dll文件,如下图所示

Reflexil_Install3

然后点击Close ,此时程序的 Tools 栏目下已经有了 Reflexil 插件选项。

要反编译的示例项目

本文反编译一个Winform程序(当然,你也可以反编译.NET 的其他 dll 文件),程序如下所示:

Reflector Winform

代码

  1. public partial class Form1 : Form
  2. {
  3. public Form1()
  4. {
  5. InitializeComponent();
  6. }
  7. private void btnTest_Click(object sender, EventArgs e)
  8. {
  9. MessageBox.Show(“你好”);
  10. }
  11. }

我们把这个exe程序进行反编译吧

开始反编译工作

首先在Reflector工具栏中依次点击 Tools -> Reflexil 打开 Reflexil 的窗口,如下图所示

Open Reflexil

然后打开你要反编译的程序集,我们编译自己写的Winform的exe程序作为测试吧,如下图所示。

Reflector Winform2

然后我们选中我们要反编译的方法,在Reflexil插件中进行反编译,如下图所示。

Reflector Winform3

可以直接在“你好”的那一栏进行点击右键选择 “Edit” 进行直接的编辑

也可以在图中的这个选项卡( Instructions ) 中的表的任意一栏点击右键选择,如下图所示

Reflexil Edit

你可以直接Edit编辑单个文本,也可以Replace all with code... 编辑整个class的内容。

如果你选择的是Replace all with code... 来编辑整个内容的话,你需要在编辑完成后,在界面的左下角点击Complile 做编译操作。

但是似乎这个插件的编辑整个class的功能有缺陷,有些代码识别不出来。所以还是看情况使用吧,如果Replace all with code..不行,就直接选 Edit 编辑我们所选的内容即可。  我这里将“你好” 修改为 “你好,欢迎访问我的博客,www.wxzzz.com”。如下所示

Reflexil Edit2修改完成后,就万事俱备 只欠东风了。

最后一步操作,依次在Reflector项目中点击右键 -> 选择 Reflexil -> 选择 Save as..

保存即可,这样就完成了修改代码,编译成功。如图

Reflexil Save

然后就ok了,运行看看:

Reflector Result

其实很简单,只是我写的可能稍微太细了点儿。

哈哈,反正看图不看文字应该也可以直接结束这篇文章。

以下是我反编译之后的程序下载地址,你可以作为练习再次反编译:TestWinform.Patched

 

【转自】https://www.cnblogs.com/jackking/p/6165294.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/119322.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • SiamFC 学习(论文、总结与分析)

    SiamFC 学习(论文、总结与分析)文章目录前言一、SiamFC论文学习1.介绍2.深度相似学习在跟踪中的应用2.1全卷积孪生结构3.引入库二、使用步骤1.引入库2.读入数据总结前言之前看了关于siamFC的论文、博客和代码,已经跑通了代码,但是,只是大概初步学习,没有认真的研究细节。为了后面更好的学习Siam系列的算法还是要重新认真的学习SiamFC。先附上论文和代码。论文:Fully-ConvolutionalSiameseNetworksforObjectTracking代码:基于pytorch框架的htt

  • ffmeg将多段视频合成一个视频「建议收藏」

    ffmeg将多段视频合成一个视频「建议收藏」ffmeg将多段视频合成一个视频文章目录:一、方法一:利用文件列表二、方法二:不利用文件列表三.方法三:拼接不同编码格式的文件四、注意事项要处理多段视频太费劲啦,如果直接把多段小视频合成一段长视频处理起来就会方便很多,类似剪辑之后的视频合并操作!!!ffmpeg视频拼接需要用concat参数。此外ffmpeg拼接的视频和原视频的封装格式有关一、方法一:利用文件列表建立一个…

  • win7显示器亮度怎么调_虚拟机外接显示器

    win7显示器亮度怎么调_虚拟机外接显示器很久没有继续研究wddmhook了,最后一次研究还在3年前,不得不说虽然应用的少,但是wddmhook却是很有技术含量的一项技术,而且实用性很高,我们除了做虚拟显示器还能做很多的东西,比如高效的截屏(因为直接从驱动层面截屏,所以效率和实现效果秒杀mirrordriver和DXGI)、视频重定向(视频硬件加速的时候可以直接获取原始码流)、修改原始的显示器厂商信息、修改显示器支持分辨率,等等骚操作wddmhook都可以实现。去年,深圳某硬件公司找到我,他们正在做usb转HDMI或者USB转VGA的硬件

  • 无损压缩视频文件_什么软件可以无损传输视频

    无损压缩视频文件_什么软件可以无损传输视频面对一些海量的高清视频的存储,一个好的高清无损视频压缩解决方案可以为整个项目本身省掉不少费用,常常有用户在苦苦寻找怎么在不损画质的情况下压缩视频。而近期航天安网接到青岛市视频压缩的需求一起来看案例吧!项目背景:为保障青岛上合峰会顺利进行,某央企公司青岛分部要求所有业务网点视频监控系统进行存储升级改造,采集的视频图像信息保存期限不得少于九十日。项目需求:某央企公司青岛分部提出了实时视频无损压缩、延时90天存储、总部调看不卡顿三项需求。方案设计:了解了青岛市各个业务网点的基础网络情况,提出了基于VD

  • 被网页挂马攻击的几个要素_网站挂马检测工具箱书籍

    被网页挂马攻击的几个要素_网站挂马检测工具箱书籍网马网马的本质是一个特定的网页,这个网页包含了攻击者精心构造的恶意代码,这些恶意代码通过利用浏览器(包括控件、插件)的漏洞,加载并执行攻击者指定的恶意软件(通常是木马)。网站挂马是黑客植入木马的一种主要手段。黑客通过入侵或者其他方式控制了网站的权限,在网站的Web页面中插入网马,用户在访问被挂马的网站时也会访问黑客构造的网马,网马在被用户浏览器访问时就会利用浏览器或者相关插件的漏洞,下载并执行…

  • 教大家一个可以用迅雷全速下载百度网盘文件的方法「建议收藏」

    教大家一个可以用迅雷全速下载百度网盘文件的方法「建议收藏」本帖最后由古道吹西风于2017-8-2822:11编辑 百度的各种限制,相信大家都是苦难言,每年赚那么多的钱,还这样小气,开通会员也一样的下载慢,我只说“我去年买了个表”这个方法网上有教程,大家也可以去网上搜一下,先看一下我家的网速,小区宽带6M 再看看下载速度 是不是全速,方法如下1.下载tampermonkey,这个google浏览器插件,插件可以去百度搜索下载。如下图 2.上传完…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号