常见保护的攻击:序列号方式

序列号保护机制

数学算法一项都是密码加密的核心,但在一般的软件加密中,他似乎并不太为人们关心,因为大多数时候软件加密本身实现的都是一种编程的技巧。但近几年来随着序列号加密程式的普及,数学算法在软件加密中的比重似乎是越来越大了。

我们先来看看在网络上大行其道的序列号加密的工作原理。当用户从网络上下载某个shareware——共享软件后,一般都有使用时间上的限制,当过了共享软件的试用期后,你必须到这个软件的公司去注册后方能继续使用。

注册过程一般是用户把自己的私人信息(一般主要指名字)连同信用卡号码告诉给软件公司,软件公司会根据用户的信息计算出一个序列码,在用户得到这个序列码后,按照注册需要的步骤在软件中输入注册信息和注册码,其注册信息的合法性由软件验证通过后,软件就会取消掉本身的各种限制,这种加密实现起来比较简单,不必额外的成本,用户购买也非常方便,在互连网上的软件80%都是以这种方式来保护的。

我们注意到软件验证序列号的合法性过程,其实就是验证用户名和序列号之间的换算关系是否正确的过程。其验证最基本的有两种,一种是按用户输入的姓名来生成注册码,再同用户输入的注册码比较,公式表示如下:

序列号 = F(用户名)

但这种方法等于在用户软件中再现了软件公司生成注册码的过程,实际上是非常不安全的,不论其换算过程多么复杂,解密者只需把你的换算过程从程式中提取出来就能编制一个通用的注册程式。

另外一种是通过注册码来验证用户名的正确性,公式表示如下:

用户名称 = F逆(序列号) (如ACDSEE,小楼注)

这其实是软件公司注册码计算过程的反算法,如果正向算法和反向算法不是对称算法的话,对于解密者来说,的确有些困难,但这种算法相当不好设计。

于是有人考虑到一下的算法:

F1(用户名称) = F2(序列号)

F1、F2是两种完全不同的的算法,但用户名通过F1算法的计算出的特征字等于序列号通过F2算法计算出的特征字,这种算法在设计上比较简单,保密性相对以上两种算法也要好的多。如果能够把F1、F2算法设计成不可逆算法的话,保密性相当的好;可一旦解密者找到其中之一的反算法的话,这种算法就不安全了。一元算法的设计看来再怎么努力也非常难有太大的突破,那么二元呢?

特定值 = F(用户名,序列号)

这个算法看上去相当不错,用户名称和序列号之间的关系不再那么清晰了,但同时也失去了用户名于序列号的一一对应关系,软件研发者必须自己维护用户名称和序列号之间的唯一性,但这似乎不是难以办到的事,建个数据库就好了。当然你也能根据这一思路把用户名称和序列号分为几个部分来构造多元的算法。

特定值 = F(用户名1,用户名2,…序列号1,序列号2…)

现有的序列号加密算法大多是软件研发者自行设计的,大部分相当简单。而且有些算法作者虽然下了非常大的功夫,效果却往往得不到他所希望的结果。其实目前有非常多现成的加密算法能用,如RSADES,MD4,MD5,只不过这些算法是为了加密密文或密码用的,于序列号加密多少有些不同。我在这里试举一例,希望有抛砖引玉的作用: 中国网管联盟

1、在软件程式中有一段加密过的密文S

2、密钥 = F(用户名、序列号)  用上面的二元算法得到密钥

3、明文D = F-DES(密文S、密钥) 用得到的密钥来解密密文得到明文D

4、CRC = F-CRC(明文D)      对得到的明文应用各种CRC统计

5、检查CRC是否正确。最佳多设计几种CRC算法,检查多个CRC结果是否都正确

用这种方法,在没有一个已知正确的序列号情况下是永远推算不出正确的序列号的。

序列号方式的保护方式就为大家介绍完了,希望大家已经掌握。如果想了解更多的相关内容,请大家阅读:常见保护的攻击:序列号方式 续

【编辑推荐】

  1. 详细解析数据加密
  2. 内部网中的密码管理
  3. 探讨ECC加密被破译的可能性
  4. 信息安全的核心之密码技术 上
  5. 密码遗忘通关手册 为你减少不必要的麻烦 上

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/128462.html<

(0)
运维的头像运维
上一篇2025-02-25 04:00
下一篇 2025-02-25 04:02

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注