Navicat Keygen – 注册机是怎么工作的?

Navicat Keygen – 注册机是怎么工作的?Navicat Keygen – 注册机是怎么工作的?

Navicat Keygen – 注册机是怎么工作的?

1. 关键词解释.

  • Navicat激活公钥

    这是一个2048位的RSA公钥,Navicat使用这个公钥来完成相关激活信息的加密和解密。

    这个公钥被作为 RCData 类型的资源储存在 navicat.exe 当中。资源名为"ACTIVATIONPUBKEY"。你可以使用一个叫Resource Hacker的软件来查看它。这个公钥的具体内容为:

    -----BEGIN PUBLIC KEY-----  
    MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAw1dqF3SkCaAAmMzs889I  
    qdW9M2dIdh3jG9yPcmLnmJiGpBF4E9VHSMGe8oPAy2kJDmdNt4BcEygvssEfginv  
    a5t5jm352UAoDosUJkTXGQhpAWMF4fBmBpO3EedG62rOsqMBgmSdAyxCSPBRJIOF  
    R0QgZFbRnU0frj34fiVmgYiLuZSAmIbs8ZxiHPdp1oD4tUpvsFci4QJtYNjNnGU2  
    WPH6rvChGl1IRKrxMtqLielsvajUjyrgOC6NmymYMvZNER3htFEtL1eQbCyTfDmt  
    YyQ1Wt4Ot12lxf0wVIR5mcGN7XCXJRHOFHSf1gzXWabRSvmt1nrl7sW6cjxljuuQ  
    awIDAQAB  
    -----END PUBLIC KEY-----  
    

    代码100分

    如果您有相应的私钥并乐意公开的话欢迎联系我,我将非常感谢您的慷慨。

    注意:

    Navicat Premium 12.0.25 开始,Navicat不再从navicat.exe的资源中加载私钥。事实上,公钥转为从libcc.dll中加载,并且已经被加密。与此同时,为了防止被轻松地替换,加密的公钥被分到5个地方储存:

    以下内容是从 Navicat Premium x64 12.0.25 简体中文版libcc.dll中发现的,libcc.dll的SHA256值为607e0a84c75966b00f3d12fa833e91d159e4f51ac51b6ba66f98d0c3cbefdce0。我不保证在Navicat的其他版本中相关偏移量和下述的相同,但相关的 字符串 以及 立即数 是很可能找得到的。

    1. libcc.dll中,文件偏移量+0x01A12090的地方,储存了加密公钥的第一部分,以 字符串 的形式储存:

      代码100分"D75125B70767B94145B47C1CB3C0755E  
       7CCB8825C5DCE0C58ACF944E08280140  
       9A02472FAFFD1CD77864BB821AE36766  
       FEEDE6A24F12662954168BFA314BD950  
       32B9D82445355ED7BC0B880887D650F5" 
      
    2. libcc.dll中,文件偏移量+0x0059D799的地方,储存了加密公钥的第二部分,以 立即数 的形式储存在一条指令中:

      0xFE 0xEA 0xBC 0x01
      

      相应的十进制值为: 29158142

    3. libcc.dll中,文件偏移量+0x01A11DA0的地方,储存了加密公钥的第三部分,以 字符串 的形式储存:

      代码100分"E1CED09B9C2186BF71A70C0FE2F1E0AE  
       F3BD6B75277AAB20DFAF3D110F75912B  
       FB63AC50EC4C48689D1502715243A79F  
       39FF2DE2BF15CE438FF885745ED54573  
       850E8A9F40EE2FF505EB7476F95ADB78  
       3B28CA374FAC4632892AB82FB3BF4715  
       FCFE6E82D03731FC3762B6AAC3DF1C3B  
       C646FE9CD3C62663A97EE72DB932A301  
       312B4A7633100C8CC357262C39A2B3A6  
       4B224F5276D5EDBDF0804DC3AC4B8351  
       62BB1969EAEBADC43D2511D6E0239287  
       81B167A48273B953378D3D2080CC0677  
       7E8A2364F0234B81064C5C739A8DA28D  
       C5889072BF37685CBC94C2D31D0179AD  
       86D8E3AA8090D4F0B281BE37E0143746  
       E6049CCC06899401264FA471C016A96C  
       79815B55BBC26B43052609D9D175FBCD  
       E455392F10E51EC162F51CF732E6BB39  
       1F56BBFD8D957DF3D4C55B71CEFD54B1  
       9C16D458757373E698D7E693A8FC3981  
       5A8BF03BA05EA8C8778D38F9873D62B4  
       460F41ACF997C30E7C3AF025FA171B5F  
       5AD4D6B15E95C27F6B35AD61875E5505  
       449B4E"
      
    4. libcc.dll中,文件偏移量+0x0059D77F的地方,储存了加密公钥的第四部分,以 立即数 的形式储存在一条指令中:

      0x59 0x08 0x01 0x00
      

      相应的十进制值为: 67673

    5. libcc.dll中,文件偏移量+0x01A11D8C的地方,储存了加密公钥的第五部分,以 字符串 的形式储存:

      "92933"
      

    这五部分按照"%s%d%s%d%s"的形式输出则为加密的公钥,顺序和上述的顺序相同,具体的输出为:

    
    D75125B70767B94145B47C1CB3C0755E7CCB8825C5DCE0C58ACF944E082801409A02472FAFFD1CD77864BB821AE36766FEEDE6A24F12662954168BFA314BD95032B9D82445355ED7BC0B880887D650F529158142E1CED09B9C2186BF71A70C0FE2F1E0AEF3BD6B75277AAB20DFAF3D110F75912BFB63AC50EC4C48689D1502715243A79F39FF2DE2BF15CE438FF885745ED54573850E8A9F40EE2FF505EB7476F95ADB783B28CA374FAC4632892AB82FB3BF4715FCFE6E82D03731FC3762B6AAC3DF1C3BC646FE9CD3C62663A97EE72DB932A301312B4A7633100C8CC357262C39A2B3A64B224F5276D5EDBDF0804DC3AC4B835162BB1969EAEBADC43D2511D6E023928781B167A48273B953378D3D2080CC06777E8A2364F0234B81064C5C739A8DA28DC5889072BF37685CBC94C2D31D0179AD86D8E3AA8090D4F0B281BE37E0143746E6049CCC06899401264FA471C016A96C79815B55BBC26B43052609D9D175FBCDE455392F10E51EC162F51CF732E6BB391F56BBFD8D957DF3D4C55B71CEFD54B19C16D458757373E698D7E693A8FC39815A8BF03BA05EA8C8778D38F9873D62B4460F41ACF997C30E7C3AF025FA171B5F5AD4D6B15E95C27F6B35AD61875E5505449B4E6767392933
    
    

    这个加密的公钥可以用我的另外一个repo(how-does-navicat-encrypt-password)解密,其中密钥为b"23970790"

    例如:

    E:GitHub>git clone https://github.com/DoubleLabyrinth/how-does-navicat-encrypt-password.git
    ...
    E:GitHub>cd how-does-navicat-encrypt-passwordpython3
    E:GitHubhow-does-navicat-encrypt-passwordpython3>python
    Python 3.6.3 (v3.6.3:2c5fed8, Oct  3 2017, 18:11:49) [MSC v.1900 64 bit (AMD64)] on win32
    Type "help", "copyright", "credits" or "license" for more information.
    >>> from NavicatCrypto import *
    >>> cipher = Navicat11Crypto(b"23970790")
    >>> print(cipher.DecryptString("D75125B70767B94145B47C1CB3C0755E7CCB8825C5DCE0C58ACF944E082801409A02472FAFFD1CD77864BB821AE36766FEEDE6A24F12662954168BFA314BD95032B9D82445355ED7BC0B880887D650F529158142E1CED09B9C2186BF71A70C0FE2F1E0AEF3BD6B75277AAB20DFAF3D110F75912BFB63AC50EC4C48689D1502715243A79F39FF2DE2BF15CE438FF885745ED54573850E8A9F40EE2FF505EB7476F95ADB783B28CA374FAC4632892AB82FB3BF4715FCFE6E82D03731FC3762B6AAC3DF1C3BC646FE9CD3C62663A97EE72DB932A301312B4A7633100C8CC357262C39A2B3A64B224F5276D5EDBDF0804DC3AC4B835162BB1969EAEBADC43D2511D6E023928781B167A48273B953378D3D2080CC06777E8A2364F0234B81064C5C739A8DA28DC5889072BF37685CBC94C2D31D0179AD86D8E3AA8090D4F0B281BE37E0143746E6049CCC06899401264FA471C016A96C79815B55BBC26B43052609D9D175FBCDE455392F10E51EC162F51CF732E6BB391F56BBFD8D957DF3D4C55B71CEFD54B19C16D458757373E698D7E693A8FC39815A8BF03BA05EA8C8778D38F9873D62B4460F41ACF997C30E7C3AF025FA171B5F5AD4D6B15E95C27F6B35AD61875E5505449B4E6767392933"))
    -----BEGIN PUBLIC KEY-----
    MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAw1dqF3SkCaAAmMzs889I
    qdW9M2dIdh3jG9yPcmLnmJiGpBF4E9VHSMGe8oPAy2kJDmdNt4BcEygvssEfginv
    a5t5jm352UAoDosUJkTXGQhpAWMF4fBmBpO3EedG62rOsqMBgmSdAyxCSPBRJIOF
    R0QgZFbRnU0frj34fiVmgYiLuZSAmIbs8ZxiHPdp1oD4tUpvsFci4QJtYNjNnGU2
    WPH6rvChGl1IRKrxMtqLielsvajUjyrgOC6NmymYMvZNER3htFEtL1eQbCyTfDmt
    YyQ1Wt4Ot12lxf0wVIR5mcGN7XCXJRHOFHSf1gzXWabRSvmt1nrl7sW6cjxljuuQ
    awIDAQAB
    -----END PUBLIC KEY-----

    注意:

    Navicat Premium 12.1.11 开始,Navicat不再用上面说的方法加载密钥。当然密钥还是储存在libcc.dll文件中。当Navicat启动时,它会用8字节长的XOR密钥来加密公钥,并储存到一个静态数据区中。当验证 激活码 时,Navicat会重新生成一样的8字节XOR密钥,并解密在静态储存区中的密文,从而获取公钥。

    libcc.dll,x64版本中,你会看到如下的几条指令:

    xoreax,"M"
    mov byte_xxxxxx,al
    ...
    xoreax,"I"
    mov byte_xxxxxx,al
    ...
    xoreax,"I"
    mov byte_xxxxxx,al
    ...
    xoreax,"B"
    mov byte_xxxxxx,al
    ...
    xoreax,"I"
    mov byte_xxxxxx,al
    ...
    xoreax,"j"
    mov byte_xxxxxx,al
    ...
    ...

  • 请求码

    这是一个Base64编码的字符串,代表的是长度为256字节的数据。这256字节的数据是 离线激活信息Navicat激活公钥 加密的密文。

  • 离线激活请求信息

    这是一个JSON风格的字符串。它包含了3个Key:"K""DI""P",分别代表 序列号设备识别码(与你的电脑硬件信息相关)和 平台 (其实就是操作系统类型)。

    例如:

    {"K": "xxxxxxxxxxxxxxxx", "DI": "yyyyyyyyyyyyy", "P": "WIN8"}
    
  • 激活码

    这是一个Base64编码的字符串,代表的是长度为256字节的数据。这256字节的数据是 离线激活回复信息Navicat激活私钥 加密的密文。目前我们不知道官方的 Navicat激活私钥,所以我们得替换掉软件里的公钥。

  • 离线激活回复信息

    离线激活请求信息 一样,它也是一个JSON风格的字符串。但是它包含5个Key,分别为"K""N""O""T""DI".

    "K""DI" 的意义与 离线激活请求信息 中的相同,且Value必须与 离线激活请求信息 中的相同。

    "N""O""T" 分别代表 注册名组织授权时间

    注册名组织 的值类型为UTF-8编码的字符串。授权时间 的值类型可以为字符串或整数(感谢@Wizr在issue #10中的报告)。

    "T" 可以被省略。

  • 序列号

    这是一个被分为了4个部分的字符串,其中每个部分都是4个字符长。

    序列号 是通过10个字节的数据来生成的。为了表达方便,我用 uint8_t data[10] 来表示这10个字节。

    1. data[0]data[1] 必须分别为 0x680x2A

      这两个字节为Navicat的标志数。

    2. data[2]data[3]data[4] 可以是任意字节,你想设成什么都行。

    3. data[5]data[6] 是Navicat的语言标志,值如下:

      语言类型 data[5] data[6] 发现者
      English 0xAC 0x88  
      简体中文 0xCE 0x32  
      繁體中文 0xAA 0x99  
      日本語 0xAD 0x82 @dragonflylee
      Polski 0xBB 0x55 @dragonflylee
      Español 0xAE 0x10 @dragonflylee
      Français 0xFA 0x20 @Deltafox79
      Deutsch 0xB1 0x60 @dragonflylee
      한국어 0xB5 0x60 @dragonflylee
      Русский 0xEE 0x16 @dragonflylee
      Português 0xCD 0x49 @dragonflylee
    4. data[7] 是Navicat产品ID。(感谢 @dragonflylee 和 @Deltafox79提供的数据)

      产品名 Enterprise Standard Educational Essentials
      Navicat Report Viewer 0x0B      
      Navicat Data Modeler 3   0x84 0x85  
      Navicat Premium 0x65   0x66 0x67
      Navicat MySQL 0x68 0x69 0x6A 0x6B
      Navicat PostgreSQL 0x6C 0x6D 0x6E 0x6F
      Navicat Oracle 0x70 0x71 0x72 0x73
      Navicat SQL Server 0x74 0x75 0x76 0x77
      Navicat SQLite 0x78 0x79 0x7A 0x7B
      Navicat MariaDB 0x7C 0x7D 0x7E 0x7F
      Navicat MongoDB 0x80 0x81 0x82  
    5. data[8] 的高4位代表 版本号。低4位未知,但可以用来延长激活期限,可取的值有00000001

      例如:

      对于 Navicat 12: 高4位必须是1100,为12的二进制形式。
      对于 Navicat 11: 高4位必须是1011,为11的二进制形式。

    6. data[9] 目前暂未知,但如果你想要 not-for-resale license 的话可以设成0xFD0xFC0xFB

      根据 Navicat 12 for Mac x64 版本残留的符号信息可知:

      • 0xFBNot-For-Resale-30-days license.
      • 0xFCNot-For-Resale-90-days license.
      • 0xFDNot-For-Resale-365-days license.
      • 0xFENot-For-Resale license.
      • 0xFFSite license.

    之后Navicat使用 ECB 模式的 DES 算法来加密 data[10] 的后8字节,也就是 data[2]data[9] 的部分。

    相应的DES密钥为:

    unsigned char DESKey = { 0x64, 0xAD, 0xF3, 0x2F, 0xAE, 0xF2, 0x1A, 0x27 };

    之后使用Base32编码 data[10],其中编码表改为:

    char EncodeTable[] = "ABCDEFGHIJKLMNOPQRSTUVWXYZ234567";

    编码之后你应该会得到一个16字节长的字符串,并且以”NAV”打头。

    将16字节的字符串分成4个4字节的小块,然后用"-"连接就可以得到 序列号

2. 激活过程

  1. 检查用户输入的 序列号 是否合法。

  2. 在用户点击了激活按钮之后,Navicat会先尝试在线激活。如果失败,用户可以选择离线激活。

  3. Navicat会使用用户输入的 序列号 以及从用户电脑收集来的信息生成 离线激活请求信息,然后用 Navicat激活公钥 加密,并将密文用Base64编码,最后得到 请求码

  4. 正常流程下,请求码 应该通过可联网的电脑发送给Navicat的官方激活服务器。之后Navicat的官方激活服务器会返回一个合法的 激活码

    但现在我们使用注册机来扮演官方激活服务器的角色,只是Navicat软件里的激活公钥得换成自己的公钥:

    1. 根据 请求码, 获得"DI"值和"K"值。

    2. "K"值、用户名、组织名和"DI"值填写 离线激活回复信息

    3. 用自己的2048位RSA私钥加密 离线激活回复信息,你将会得到256字节的密文。

    4. 用Base64编码这256字节的密文,就可以得到 激活码

    5. 在Navicat软件中填入 激活码 即可完成离线激活。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/10586.html

(0)
上一篇 2022-12-25 10:30
下一篇 2022-12-25

相关推荐

  • Python脚本如何执行

    Python脚本如何执行Python是一种高级编程语言,具有简单易学、强大而又灵活的特点。Python脚本是一种编写Python语言程序的方法,它可以在各种操作系统上运行。Python脚本执行的方式与其他语言的程序不同,本文将介绍Python脚本如何执行以及它的一些特点。

    2024-09-07
    20
  • 陈宏申:浅谈京东电商商品文案挖掘难点与优化实践[亲测有效]

    陈宏申:浅谈京东电商商品文案挖掘难点与优化实践[亲测有效]导读: 在电商推荐中,除了推送商品的图片和价格信息外,文案也是商品非常重要的维度。基于编码器解码器范式的序列文本生成模型是文案挖掘的核心,但该种方法面临着两大技术挑战:一是文案生成结果不可靠和生成质量

    2023-05-19
    147
  • 第3篇:分布式数据库存储

    第3篇:分布式数据库存储一、分布式数据库存储 在前面的章节;GreenPlum数据库是分布式架构数据库;表的数据分布在segment节点。那么表的数据根据什么策略来分布的? GreenPlum数据库性能依赖于跨数据节点均匀分

    2022-12-24
    160
  • 数据库和 SQL 是什么关系「终于解决」

    数据库和 SQL 是什么关系「终于解决」本文介绍数据库的结构和基本理论,以及数据库的实际应用。同时还介绍关系数据库专用的 SQL 语句的书写方法和规则。 一、数据库是什么 本节重点 数据库是将大量数据保存起来,通过计算机加工而成的可以进行高

    2023-05-19
    125
  • Python解析JSON数据

    Python解析JSON数据JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,由JavaScript对象表示和存储数据。它常用于Web前后端交互和移动应用。Python内置了强大的JSON解析库,可以轻松解析和生成JSON数据。

    2024-09-01
    28
  • Python下直观易懂的解析

    Python下直观易懂的解析Python是一种高级编程语言,它的解释执行可以让开发者更加专注于业务逻辑而不是底层的代码实现。Python的解释器会将Python代码翻译成字节码,并在Python虚拟机上执行这些字节码。同时,Python是一种动态的语言,它能够根据上下文自动推断数据类型,这使得Python编写的程序更加简洁易懂。

    2024-01-01
    131
  • 如何在mac上升级Python

    如何在mac上升级Python随着Python的升级和更新,我们需要不断地升级我们使用的Python版本。虽然macOS自带Python,但是通常使用的版本较老,可能不能满足最新的需求,因此这篇文章将介绍如何在macOS上升级Python。

    2024-09-21
    12
  • Python字符串的分割方法:split()

    Python字符串的分割方法:split()在Python中,字符串是一个非常常用的数据类型。在处理字符串时,有许多方法可以使用,其中最常用的莫过于split()方法。split()方法可以将一个字符串分割成多个子字符串,返回一个包含子字符串的列表。split()方法还可以接收一个参数,用于指定分割字符,如果不指定,则默认以空格为分隔符。

    2023-12-04
    174

发表回复

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