反编译DLL文件

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

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找到该软件;spa

 

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

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

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

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

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

 

步骤三:咱们能够打开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;
复制代码
相关文章
相关标签/搜索