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

时间:2022-04-20 15:08:33

如: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

哈哈 就这个。。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
.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编译中间代码

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

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

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

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

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

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

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

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

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

?
1
2
3
4
5
6
7
8
9
10
.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文件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持服务器之家。