博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用JustDecompile修改程序集
阅读量:7050 次
发布时间:2019-06-28

本文共 1358 字,大约阅读时间需要 4 分钟。

原文:

       是Telerik公司推出一个免费的.net反编译工具,支持插件,与 2010,2012集成,能够创建Visual Studio project文件。今天我们使用其一个插件来修改程序集。首先,我们来写一个非常简单的时间限制程序:

1:          static void Main(string[] args)
2:          {
3:              Timebomb();
4:          }
5:          static void Timebomb()
6:          {
7:              var message = "Welcome to demo";
8:              if (DateTime.Now > new DateTime(2012, 12, 01))
9:              {
10:                  Environment.Exit(0);
11:              }
12:              Console.WriteLine(message);
13:              Console.Read();
14:          }
看上面的代码,可以看出程序时,检查当前时间是否过期,如果是就退出了。假设我没有程序的源代码,下面用这个工具解除这个时间限制的问题:

通过反编译后,我们看到IL, 假设您对有一定的了解。offset 39 

ldc.i4.0

意思是将常数0做为4个字节整数压入栈,  offset 40 接着是

call  System.Void System.Environment::Exit(System.Int32) 

意思是调用System.dll中Environment类。我们还可以看到具体的时间,你可修改他们,让我们来修改多点儿东西。我们在上面单击右键选择Edit,把这两条IL分别修改为nop 操作,从而达到让主程序不退出的效果,最后在上面点击右键另存为新的程序集。

最后运行刚才另存为的程序集,结果与我们期待的一致。此时我们反编译程序集的这个方法,是如下代码:

1:  private static void Timebomb()
2:  {
3:      string str = "Welcome to demo";
4:      if (DateTime.Now > new DateTime(0x7dc, 10, 9))
5:      {
6:      }
7:      Console.WriteLine(str);
8:      Console.Read();
9:  }
10:   
11:
小结,对于没有混淆的程序集,我们可以看懂代码逻辑,在没有源代码的情况,借用Reflexil插件可以简单修改IL,实现想要的结果。这里的例子很简单,希望您能举一反三,实际情况可能比较复杂。

希望对您软件开发有帮助。

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

你可能感兴趣的文章
python进阶-面向对象编程五:类的内置方法
查看>>
JAVA入门到精通-第52讲-面试题讲评
查看>>
05-spark streaming & kafka
查看>>
python杂记
查看>>
cd 简化命令
查看>>
LeetCode--205--同构字符串
查看>>
python-ConfigParser模块【读写配置文件】
查看>>
wireshark使用方法总结
查看>>
Window Server 2008 R2 TFS2010 安装前的准备
查看>>
20141123
查看>>
translucent 属性
查看>>
android listView嵌套gridview的使用心得
查看>>
[ES7] Descorator: evaluated & call order
查看>>
安卓动态调试七种武器之离别钩 – Hooking(上)
查看>>
从P6 EPPM 8 R3 到P6 EPPM 16 R1 有哪些改变?
查看>>
Android Studio2.0 教程从入门到精通Windows版 - 安装篇
查看>>
Linux 系统磁盘满处理方法
查看>>
Java HashMap Demo
查看>>
yaml官方介绍
查看>>
three.js模型
查看>>