转一篇DLL逆向的文章,适用于一般的dll逆向

转一篇DLL逆向的文章,适用于一般的dll逆向,我使用的库是一组DLL,都有强签名,如下方法不适合,编译会提示强签名错误。

C# 带签名dll破解

Mar 9, 2016 | C# | 84 Hits

转自 http://blog.fwhyy.com/2016/03/csharp-with-signature-dll-crack/?utm_source=tuicool&utm_medium=referral

暂无评论

首先申明,本文只是从技术的角度来分析下怎样破解带签名的C#写的dll文件。大家如有遇到收费的软件或类库还是应该去购买正版,程序员何苦为难程序员呢。

不带签名的破解

不带签名的dll文件的破解很简单,通常有下面三个步骤:

  1. 使用反编译工具对dll文件进行反编译,找到校验过期的相关代码,反编译工具可以使用ILSpy或Reflector;
  2. 使用ildasm.exe工具将dll导出成il文本文件,在该文件中找到相关的代码进行修改;
  3. 使用ildasm.exe工具将修改后的il文件编译成dll文件。

下面看一个例子,假设有ClassLibrary1.dll文件,该类库中的有关校验过期的代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14


public static class License

{

private static bool licenseExpired;

internal static void CheckLicense()

{

//if语句中判断是否过期

if(true)

{

//标示是否过期,设置成true表示过期

License.licenseExpired = true;

}

}

}

使用ILSpy进行反编译看到的代码如下:

wpid-14574474852300

现在使用ildasm.exe对该dll文件进行导出成il文本文件:

wpid-14574476388347

使用文本编辑器打开il文件,找到校验对相关代码:

wpid-14574478634829

  1. 上图中的红框部分代码对应的就是License.licenseExpired = true;这行代码;
  2. 第97行代码IL_0004:ldc.i4.1代表的就是true,等待着赋值给下面的licenseExpired;
  3. 修改97行的代码为IL_0004:ldc.i4.0,然后保存il文件。

打开命令行,进入到il文件所在到目录,执行下面的命令;


1

c:\windows\microsoft.net\framework\v4.0.30319\ilasm.exe /dll/resource=ClassLibrary1.res ClassLibrary1.il

wpid-14574490215799

现在在il文件的目录中可以看到生成的dll文件:

wpid-14574491293072

反编译生成的dll文件,可以看出代码已经被修改,如下图:

wpid-14574491097269

带签名dll的破解

如果程序集是带签名的程序集,在经过上面的步骤进行破解后,dll文件依然不能正常使用,通常会报如下错误:

未能加载文件或程序集“ClassLibrary1”或它的某一个依赖项。未能验证强名称签名。此程序集可能已被篡改,或者已被延迟签名,但没有用正确的私钥进行完全签名。 (异常来自 >HRESULT:0x80131045)

经过对比发现经过签名的dll文件和未签名的dll文件的区别在于签名的dll文件生成的il代码中会多处如下的代码:

wpid-14574511220078

将il代码中上面红框部分代码删除,重新生成的dll文件就是去掉了签名的dll文件。不出什么意外的话此时的dll文件可以正常使用了,但有时又会出现如下的错误:

重写成员“xxx”时违反了继承安全性规则。重写方法的安全可访问性必须与所重写方法的安全可访问性匹配

解决该问题需要在Assemblyinfo.cs文件中添加如下代码:


1

[assembly: System.Security.SecurityRules(System.Security.SecurityRuleSet.Level1)]

wpid-14574514129726

上面添加的代码对应的il代码为:


1

.custom instance void [mscorlib]System.Security.SecurityRulesAttribute::.ctor(valuetype [mscorlib]System.Security.SecurityRuleSet) = ( 01 00 01 00 00 )

将上面的代码添加到il的相应位置,重新生成dll文件就OK了。

总结

本文是以技术研究学习为目的,不提倡对收费的软件或类库进行破解使用。

时间: 2024-10-10 06:04:09

转一篇DLL逆向的文章,适用于一般的dll逆向的相关文章

(转)干货|这篇TensorFlow实例教程文章告诉你GANs为何引爆机器学习?(附源码)

干货|这篇TensorFlow实例教程文章告诉你GANs为何引爆机器学习?(附源码) 该博客来源自:https://mp.weixin.qq.com/s?__biz=MzA4NzE1NzYyMw==&mid=2247492203&idx=5&sn=3020c3a43bd4dd678782d8aa24996745&chksm=903f1c73a74895652ee688d070fd807771e3fe6a8947f77f3a15a44a65557da0313ac5ad592c

《转载-两篇很好的文章整合》Android中自定义控件

两篇很好的文章,有相互借鉴的地方,整合到一起收藏 分别转载自:http://blog.csdn.net/xu_fu/article/details/7829721 http://www.cnblogs.com/0616--ataozhijia/p/4003380.html Android系统的视图结构的设计也采用了组合模式,即View作为所有图形的基类,Viewgroup对View继承扩展为视图容器类,由此就得到了视图部分的基本结构--树形结构 View定义了绘图的基本操作 基本操作由三个函数完

A博娱乐十篇必读的Java文章

A博娱乐一个月前,我们发布了一份<十篇必读的SQL文章>清单,我们相信这些文章将为jOOQ博客的读者提供 极大的价值.jooQ是一个专注于Java和SQL的博客,所以一个月后的今天,我们发布一份同样令人兴奋 的<十篇必读的Java文章>清单,是再自然不过的事情. 请注意对于"必读的"这个描述,我们不仅仅特指某一篇链接的文章,也可能包含来自同一作者的其 它文章,这些作者在这些年一直是博客的中坚力量,总是能创造新的令人关注的内容. 让我们来看看吧! 1.Brian

看到一篇很有意思的文章,但是我们身边确实有这样的人

我在代码之路上曾经遇到过很多奇怪的对手,也遇到过奇怪的队友.我至少接触了五种不同的"代码斗士".其中一些有才的战友有助于开发工作的进行,而另一些看起来阻碍了我的每一个计划. 然而,他们全都在软件开发的"万神殿"中拥有一席之地.如果不能将这些不同风格的程序员协调好的话,你会发现你的项目会花费很多时间.不够稳定或者代码难以读懂等问题. 补漏灵型 该死,代码虽然不够完美,但是能工作就行了! 这种人是你公司的基础.当哪里出现差错的时候他会迅速的修补,在某种程度上,保证不会再

如何写一篇优质的原创文章

对于一个网站来说,网站的内容是其重中之重,而网站的原创优质内容就是一个网站的灵魂.网站就好比一个人,每个人都是独一无二的,世界上没有完全相同的两个人,也就没有完全相同的两个灵魂. 网站要有灵魂,要有自己优质的东西,要有自己的主见.在显示生活中,有很多成功的人,他们的成功引来很多人的模仿,希望他们也能一样的成功.有的人虽然模仿很想了,但是却没有模仿而成功过.人都是在模仿学习中成长,但是在学习模仿的过程中他们加入了自己的思想,而这成为他们成功的关键.而这些思想,是他人无法抄袭和复制的的.同样,一个网

# 中静态调用C++dll 和C# 中动态调用C++dll

C# 中静态调用C++dll 和C# 中动态调用C++dll 在最近的项目中,牵涉到项目源代码保密问题,由于代码是C#写的,容易被反编译,因此决定抽取核心算法部分使用C++编写,C++到目前为止好像还不能被很好的反编译,当然如果你是反汇编高手的话,也许还是有可能反编译.这样一来,就涉及C#托管代码与C++非托管代码互相调用,于是调查了一些资料,顺便与大家分享一下: 一. C# 中静态调用C++动态链接 1. 建立VC工程CppDemo,建立的时候选择Win32 Console(dll),选择Dl

C# 中静态调用C++dll 和C# 中动态调用C++dll

C# 中静态调用C++dll 和C# 中动态调用C++dll 在最近的项目中,牵涉到项目源代码保密问题,由于代码是C#写的,容易被反编译,因此决定抽取核心算法部分使用C++编写,C++到目前为止好像还不能被很好的反编译,当然如果你是反汇编高手的话,也许还是有可能反编译.这样一来,就涉及C#托管代码与C++非托管代码互相调用,于是调查了一些资料,顺便与大家分享一下: 一. C# 中静态调用C++动态链接 1. 建立VC工程CppDemo,建立的时候选择Win32 Console(dll),选择Dl

C# 动态修改dll的签名 以及修改引用该dll文件的签名

原文:C# 动态修改dll的签名 以及修改引用该dll文件的签名 在读取RedisSessionStateProvider配置 提到用mono ceil 来修改程序集以及它的签名,里面GetPublicKey 和GetPubliKeyToken 方法里面那个字符串的获取 以及后来的签名 我们都应该 用code来实现,还有应用该dll文件的签名也一同需要修改. 所以我这里实现了一个简单的helper方法 如下: namespace ConsoleSession { using Mono.Cecil

转帖一篇sixxpack破解的文章!

星期天闲着没事玩游戏,玩游戏不能无外挂.于是百度了半天,找到了一个,看介绍貌似不错,就下载了下来.一看,竟然是用.net写的,下意识地Reflector了一下.发现竟是一个叫actmp的程序集.如图: 随便点开看了看,没发现什么和外挂有关的东西.奇怪,于是又百度了一下"actmp.dll",发现了这篇文章http://blog.csdn.net/yizhiduxiu11/archive/2008/12/23/3589396.aspx,其中说"经Sixxpack加壳后,用Ref