我们平时在工作中经常会遇到一些已经被编译后的DLL,而且更加麻烦是没有源代码可以进行修改,只能针对这个DLL的文件进行修改才能得到我们想要的结果;本文将通过一个实例来演示如果完成一个简单的修改;我们将会用到以下几种工具;

1:反编译工具ILSpy.exe:是个很不错的反编译软件,而且是免费了;

2:微软的工具ildasm.exe:这个是把DLL生成IL文件的一个软件,是微软自带了;可以在C:\Program Files\Microsoft SDKs\Windows\v7.0A\bin找到该软件;

3:微机的工具ilasm.exe:这个是把IL文件重新生成DLL的功能,可以在C:\Windows\Microsoft.NET\Framework\v4.0.30319找到该软件;

我们新建一个WEB项目,模拟它要插入加密狗才能运行,当然这边的加密狗是我们的一个比喻,实例很简单七个步骤就可以完在;

步骤一:使用ILSpy.exe打开Web.dll文件;查看其源代码的情况:

从上面反编译出来的源代码不难发现重点是在GetLicense()方法,这个也是我们要修改的内容,从上面可以看出在没有修改前这个都是会提示要插入加密狗的;

步骤二:接下来就是要使用ildasm.exe把DLL这个文件转化成IL文件;

把dll文件转储为*.il文件存到某个指定文件夹里,得到Web.il和Web.res两个文件,有时也会有*.resource文件

步骤三:我们可以打开Web.il文件,里面有DLL生成的IL内容,我们很容易就可以定位到想要的这个方法,只要让它固定返回true就可以达到修改成功,方法内的IL代码就是我们要修改的内容;

步骤四:修改GetLicense()方法内的IL代码,让它固定返回true;下面这个IL就是让它返回为true;修改完接着保存IL文件;

步骤五:当修改完IL文件后要把它转化成DLL文件,打开DOC命令输入进入到*.il的文件夹,然后输入命令:c:\windows\microsoft.net\framework\v4.0.30319\ilasm.exe /dll/resource=Web.res Web.il

*1:要进入IL文件的文件夹 2:其中"/dll/"这个前面要有一个空格 3:.res文件要在.il文件前面,中间要有个空格

步骤六:运行完上面的命令后会生成一个新DLL文件,然后把它复制到我们的站点下面:

步骤七:运行的结果:

完成上面的七个步骤就可以成功修改DLL文件,当然本实例只是一个简单的修改,若要进行比较复杂修改IL代码则要对IL知识有个相当的了解;下面是一个可能会经常要用到的IL返回true跟false的代码;

    .maxstack 1
.locals init (
[0] bool CS$1$0000)
L_0000: nop
L_0001: ldc.i4.1
L_0002: stloc.0
L_0003: br.s L_0005
L_0005: ldloc.0
L_0006: ret return true; // 代码大小 7 (0x7)
.maxstack 1
.locals init ([0] bool CS$1$0000)
IL_0000: nop
IL_0001: ldc.i4.0
IL_0002: stloc.0
IL_0003: br.s IL_0005 IL_0005: ldloc.0
IL_0006: ret return false;

最新文章

  1. 一篇对iOS音频比较完善的文章
  2. SQL Server Reporting Services:无法检索应用程序文件。部署中的文件已损坏
  3. final的使用
  4. CSharper 学Quick-Cocos2d-X (一) 开发环境的搭建
  5. CSS级联和继承
  6. poj 2239 二分图最大匹配,基础题
  7. cygwin下的vim 的vimrc配置
  8. ejabberd 的框架
  9. dota BP练习工具开发:一个C/S多用户程序
  10. JVM学习笔记(一)------基本结构【转】
  11. 检索COM 类工厂中CLSID 为 {00024500-0000-0000-C000-000000000046}的组件时失败
  12. 【Linux】设定一个能输入中文的英文环境!
  13. 使用dispatch_once:创建单列
  14. INERT DELEYED、INSERT IGNORE replace into和insert区别
  15. poj 1715 Hexadecimal Numbers 排列组合
  16. ASP.NET Zero--5.配置权限
  17. HTML5 拖放(Drag 和 Drop)详解与实例(转)
  18. consoleWriter.go
  19. Java数据库学习之模糊查询(like )
  20. linux下将普通用户加入到docker组,使它可以运行docker命令

热门文章

  1. OV5640数据的解码
  2. 扩linux 主分区 xfs 格式的
  3. js 评论时间换算
  4. office365启动突然提示注册表错误,无法打开“规则”配置的解决方案
  5. k8s入门_RC、RS、Deployment
  6. SATA硬盘的数据和电源接口定义(转)
  7. 36.Vim笔记
  8. 【C学习笔记】day2-3 求10 个整数中最大值
  9. idea设置类,方法模板 阿里检测
  10. deployment.yml参考