反編譯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;
複製代碼
相關文章
相關標籤/搜索