欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

编辑IL文件 修改DLL文件的方法

程序员文章站 2023-11-14 18:23:40
如:ks.gantt.dll 为例 1、使用ilspy反编译 工具 2、利用ildasm反编译 ks.gantt.dll  生成il中间代码 一般会生成...

如:ks.gantt.dll 为例

1、使用ilspy反编译 工具

2、利用ildasm反编译 ks.gantt.dll  生成il中间代码 一般会生成 *.il 和*.res 一些其它资源文件 *.resources

3、然后用记事本修改il文件

4、然后用ilasm编译中间代码,生成新的ks.gantt.dll

5、在项目中使用 查看效果

破解过程

1 我找到了gantt 控件的验证的代码

编辑IL文件 修改DLL文件的方法

2 利用ildasm反编译 ks.gantt.dll

编辑IL文件 修改DLL文件的方法

3 打开il文件找到对应的代码然后删除掉 如果不会 去学习一哈 怎么使用il

哈哈 就这个。。

.try
  {
   il_0260: ldarg.0
   il_0261: ldtoken  ks.gantt.gantt
   il_0266: call    class [mscorlib]system.type [mscorlib]system.type::gettypefromhandle(valuetype [mscorlib]system.runtimetypehandle)
   il_026b: ldarg.0
   il_026c: call    class [system]system.componentmodel.license [system]system.componentmodel.licensemanager::validate(class [mscorlib]system.type,
                                                               object)
   il_0271: stfld   class [system]system.componentmodel.license ks.gantt.gantt::license
   il_0276: leave.s  il_0297

  } // end .try
  catch [mscorlib]system.exception 
  {
   il_0278: pop
   il_0279: call    bool [mscorlib]system.diagnostics.debugger::get_isattached()
   il_027e: brtrue.s  il_0295

   il_0280: newobj   instance void ks.gantt.frmabout::.ctor()
   il_0285: stloc.0
   il_0286: ldloc.0
   il_0287: callvirt  instance valuetype [system.windows.forms]system.windows.forms.dialogresult [system.windows.forms]system.windows.forms.form::showdialog()
   il_028c: pop
   il_028d: ldloc.0
   il_028e: callvirt  instance void [system]system.componentmodel.component::dispose()
   il_0293: ldnull
   il_0294: stloc.0
   il_0295: leave.s  il_0297

  } 

4 然后用ilasm编译中间代码

ilasm /dll /output=d:\mydll\ks.gantt.dll /resource=d:\mydll\gantt.res d:\mydll\gantt.il


编辑IL文件 修改DLL文件的方法

我一看到这几个单词。我就知道成功了。。

5 然后在去验证一哈dll文件

编辑IL文件 修改DLL文件的方法

那个授权验证代码不在了哈。。

不过呢。后来我测试 。我发现在这个dll不能用的。运行会报这个错的

unhandled exception: system.io.fileloadexception: strong name validation failed 

所以又得删除那个签名,删除以下所有内容

.publickey = (00 24 00 00 04 80 00 00 94 00 00 00 06 02 00 00  // .$.............. 
        00 24 00 00 52 53 41 31 00 04 00 00 01 00 01 00  // .$..rsa1........ 
        3b b2 d0 f9 da 7e 55 b2 50 40 6b cf eb 20 f6 67  // ;....~u.p@k.. .g 
        e7 d6 af 65 32 4f 6d 21 5d 91 53 0b 04 c7 e2 15  // ...e2om!].s..... 
        f0 6a ee 38 f8 74 db 22 34 f9 a1 b5 16 c1 04 66  // .j.8.t."4......f 
        b7 0b a8 36 49 9e 8a 71 e1 d1 26 ab a2 78 4e 3a  // ...6i..q..&..xn: 
        8b 71 8c 7f 4d 54 22 28 5f 1f 8d de 6c 96 ec 22  // .q..mt"(_...l.." 
        34 8a 35 3f 95 0a f4 f4 7f b7 8c f5 5d f4 cb 54  // 4.5?........]..t 
        92 94 dd 5e d5 0d 20 12 7f b1 9b 15 7f 0e fb 2a  // ...^.. ........* 
        76 5f 45 3d 20 2c e2 6d fe 55 72 30 49 76 28 fe ) // v_e= ,.m.ur0iv(.

最后在从新编译dll。成功了

以上这篇编辑il文件 修改dll文件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。