特别声明:本文仅供个人研究和学习使用,禁止任何商业用途,如需商用,请支持正版软件,否则后果自负。如果本文伤害了您的权益,请联系我,我会及时删除本文。所提供的软件均来自互联网。
准备工作
本系统是deepin11.5
参考的楼主是Ubuntu1804
参考 //www.greatytc.com/p/e0300b8a718e
git相关安装具体自行百度
一、安装GCC9.X(这里安装的是9.2)
其他版本的linux系统,基本也可以这么装
如果本地gcc 版本是9.X 或 以上 可以跳过这里,直接到第二步
root:~/Desktop$ gcc --version
gcc (GCC) 9.2.0
Copyright © 2019 Free Software Foundation, Inc.
本程序是自由软件;请参看源代码的版权声明。本软件没有任何担保;
包括没有适销性和某一专用目的下的适用性担保。
1、安装GMP(6.1)
wget 下不动的话,可以试试下面的连接,然后ctrl f 搜索 gmp-6.1.0.tar.bz2
cd /tmp
wget -P /tmp ftp://gcc.gnu.org/pub/gcc/infrastructure/gmp-6.1.0.tar.bz2
tar -xvpf gmp-6.1.0.tar.bz2
cd gmp-6.1.0
./configure --prefix=/usr/local/gmp-6.1.0 --disable-shared --enable-static
make -j4
make check
sudo make install
2、安装MPFR(3.1.4)
wget 下不动的话,可以试试下面的连接,然后ctrl f 搜索 mpfr-3.1.4.tar.bz2
cd /tmp
wget -P /tmp ftp://gcc.gnu.org/pub/gcc/infrastructure/mpfr-3.1.4.tar.bz2
tar xvpf mpfr-3.1.4.tar.bz2
cd mpfr-3.1.4
./configure --prefix=/usr/local/mpfr-3.1.4 \
--disable-shared --enable-static \
--with-gmp=/usr/local/gmp-6.1.0
make -j4
make check
sudo make install
3、安装MPC(1.0.3)
wget 下不动的话,可以试试下面的连接,然后ctrl f 搜索 mpc-1.0.3.tar.gz
cd /tmp
wget -P /tmp ftp://gcc.gnu.org/pub/gcc/infrastructure/mpc-1.0.3.tar.gz
tar zxvf mpc-1.0.3.tar.gz
cd mpc-1.0.3
./configure --prefix=/usr/local/mpc-1.0.3 \
--disable-shared --enable-static \
--with-mpfr=/usr/local/mpfr-3.1.4
make -j4
make check
sudo make install
4、编译安装GCC 9.2
编译时间取决于你电脑配置,我编译了一个小时左右。
wget 下不动的话,可以试试下面的连接,然后ctrl f 搜索 gcc-9.2.0.tar.gz
cd /tmp
wget -P /tmp http://mirrors.ustc.edu.cn/gnu/gcc/gcc-9.2.0/gcc-9.2.0.tar.gz
tar zxvf gcc-9.2.0.tar.gz
cd gcc-9.2.0
./configure --prefix=/usr/local/gcc-9.2.0 --disable-multilib --enable-languages=c,c++ \
--with-gmp=/usr/local/gmp-6.1.0 \
--with-mpfr=/usr/local/mpfr-3.1.4 \
--with-mpc=/usr/local/mpc-1.0.3
make -j4
sudo make install
5、创建文件链接
cd /usr/local/gcc-9.2.0/bin
for f in *; do sudo ln -s /usr/local/gcc-9.2.0/bin/${f} /usr/local/bin/; done
二、编译patcher-keygen
1、编译环境准备
# 编译patcher-keygen需要以下几个库支持
# capstone
# keystone (需要cmake)
# rapidjson
# 安装 capstone cmake rapidjson
sudo apt-get install libcapstone-dev cmake rapidjson-dev -y
# 安装 keystone
git clone https://github.com/keystone-engine/keystone.git
# 进入keystone的目录
cd keystone
# 创建一个build目录用于存放keystone编译后的库文件
mkdir build
# 进入创建的build目录
cd build
# 执行上级目录中的make-share.sh脚本
../make-share.sh
# 安装keystone动态库
sudo make install
# 执行dconfig动态链接库为系统所共享
sudo ldconfig
2、编译patcher-keygen
# 从git仓库拉取 patcher-keygen 的linux分支
git clone -b linux --single-branch https://github.com/HeQuanX/navicat-keygen-tools.git
# 进入 navicat-keygen-tools 目录
cd navicat-keygen-tools
# 执行编译安装(注:执行make all需要gcc9.x以上才能支持,参考)
make all
# make all执行完毕且无误后,会在 navicat-keygen-tools/bin/ 文件夹下看到编译后的keygen/patcher
解决办法:
sudo apt-get install libssl-dev
三、处理navicat.AppImage
# 首先去navicat官网下载需要的(linux)版本(这里使用navicat15简体中文版作为演示)
# 进入到你navicat所在的目录
cd xxx
# 创建一个目录作为navicat的挂载点
mkdir navicat15-premium-mount
# 将下载的navicat挂载到刚才创建的目录下
sudo mount -o loop navicat15-premium-cs.AppImage navicat15-premium-mount
# 将挂载目录里的文件拷贝至一个新的目录下(因为挂载点权限为read-only)
cp -r navicat15-premium-mount navicat15-premium-cs-temp
# 取消挂载
sudo umount navicat15-premium-mount
# 删除挂载目录(创建这个目录主要是为了将AppImage里的东西拷贝出来)
rm -rf navicat15-premium-mount
# 现在所有的文件应该是在navicat15-premium-cs-temp这个目录中,如果没有请重新执行这一步
四、使用 navicat-patcher 替换navicat官方公钥
# 注:若第2步make all执行完毕且无误后,会在 navicat-keygen-tools/bin/ 文件夹下看到编译后的navicat-patcher
# Usage:
# [可选参数,应用补丁 默认空]
# [--dry-run] Run patcher without applying any patches.
# This parameter is optional.
# <必填参数,navicat安装路径 即:上一步中的navicat15-premium-cs-temp目录>
# <Navicat Installation Path> Path to a directory where Navicat locates
# This parameter must be specified.
# [可选参数,生成的rsa私钥存储路径 默认当前路径]
# [RSA-2048 Private Key File] Path to a PEM-format RSA-2048 private key file.
# This parameter is optional.
# 例:navicat-patcher [--dry-run] <Navicat Installation Path> [RSA-2048 Private Key File]
# navicat-keygen 在第三步 navicat-keygen-tools/bin里面
./bin/navicat-patcher navicat15-premium-cs-temp
这里可能会出现libstdc++.so.6: version `GLIBCXX_3.4.21' not found的问题。
解决办法:
https://blog.csdn.net/weixin_33726318/article/details/91592433
注意/usr/lib64 是楼主的路径,不一定是你本地的路径
执行以下命令,查找编译gcc时生成的最新动态库:
# find / -name "libstdc++.so*"
输出如下:
/home/gcc-5.2.0/gcc-temp/stage1-x86_64-unknown-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so
/home/gcc-5.2.0/gcc-temp/stage1-x86_64-unknown-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6
/home/gcc-5.2.0/gcc-temp/stage1-x86_64-unknown-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.21 //最新动态库
/home/gcc-5.2.0/gcc-temp是升级gcc时的输出目录。
# 将上面的最新动态库libstdc++.so.6.0.21复制到/usr/lib64目录下:
cp /home/gcc-5.2.0/gcc-temp/stage1-x86_64-unknown-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.21 /usr/lib64
# 复制后,修改系统默认动态库的指向,即:重建默认库的软连接。
# 切换工作目录至/usr/lib64:
cd /usr/lib64
# 删除原来软连接:
rm -rf libstdc++.so.6
# 将默认库的软连接指向最新动态库:
ln -s libstdc++.so.6.0.21 libstdc++.so.6
下面是正确执行navicat-patcher后的样例输出
**********************************************************
* Navicat Patcher (Linux) by @DoubleLabyrinth *
* Version: 1.0 *
**********************************************************
Press ENTER to continue or Ctrl + C to abort.
[+] Try to open libcc.so ... Ok!
[+] PatchSolution0 ...... Ready to apply
RefSegment = 1
MachineCodeRva = 0x000000000141fbf0
PatchMarkOffset = +0x0000000002a25648
[*] Generating new RSA private key, it may take a long time...
[*] Your RSA private key:
-----BEGIN RSA PRIVATE KEY-----
MIIEpQIBAAKCAQEAwku22/m8V7ieTHg0G/WUpJFrnd7h+dpV39zfCp2M2+Isqpb7
<!-- 此处省略若干 -->
A1PusGVrzguvA+f3ZnjmfchwIHdz5f1rxnYuT6Ul0c7YSiBnIDY44r4=
-----END RSA PRIVATE KEY-----
[*] Your RSA public key:
-----BEGIN PUBLIC KEY-----
MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAwku22/m8V7ieTHg0G/WU
<!-- 此处省略若干 -->
h94x5jHGCCv0VoE2NKGHxGHZ6E6/eM2dImQhO7++htOvBMtH3/pBoQeTplwc/fpN
wwIDAQAB
-----END PUBLIC KEY-----
*******************************************************
* PatchSolution0 *
*******************************************************
[*] Previous:
+0x0000000000000070 01 00 00 00 05 00 00 00 ........
<!-- 此处省略若干 -->
+0x00000000000000a0 48 56 a2 02 00 00 00 00 00 10 00 00 00 00 00 00 HV..............
[*] After:
+0x0000000000000070 01 00 00 00 05 00 00 00 ........
<!-- 此处省略若干 -->
+0x00000000000000a0 d8 57 a2 02 00 00 00 00 00 10 00 00 00 00 00 00 .W..............
[*] Previous:
+0x0000000002a25640 00 00 00 00 00 00 00 00 ........
<!-- 此处省略若干 -->
+0x0000000002a257d0 00 00 00 00 00 00 00 00 ........
[*] After:
+0x0000000002a25640 ef be ad de 4d 49 49 42 ....MIIB
+0x0000000002a25650 49 6a 41 4e 42 67 6b 71 68 6b 69 47 39 77 30 42 IjANBgkqhkiG9w0B
<!-- 此处省略若干 -->
+0x0000000002a257c0 6f 51 65 54 70 6c 77 63 2f 66 70 4e 77 77 49 44 oQeTplwc/fpNwwID
+0x0000000002a257d0 41 51 41 42 ad de ef be AQAB....
[*] Previous:
+0x000000000141fbf0 44 0f b6 24 18 48 8b 44 24 28 8b 50 f8 85 d2 79 D..$.H.D$(.P...y
+0x000000000141fc00 6f o
[*] After:
+0x000000000141fbf0 45 31 e4 48 8d 05 52 5a 60 01 90 90 90 90 90 90 E1.H..RZ`.......
+0x000000000141fc00 90 .
[*] New RSA-2048 private key has been saved to
/home/mrhe/application/navicat-keygen-tools/bin/RegPrivateKey.pem
*******************************************************
* PATCH HAS BEEN DONE SUCCESSFULLY! *
* HAVE FUN AND ENJOY~ *
*******************************************************
五、将替换官方公钥后的文件打包
# 下载 AppImage 打包工具
wget 'https://github.com/AppImage/AppImageKit/releases/download/continuous/appimagetool-x86_64.AppImage'
# 赋予 AppImage 可执行权限
sudo chmod +x appimagetool-x86_64.AppImage
#使用 AppImage 将navicat15-premium-cs-temp打包为navicat15-premium-cs.AppImage
./appimagetool-x86_64.AppImage navicat15-premium-cs-temp navicat15-premium-cs.AppImage
# 赋予刚才打包的navicat15-premium-cs.AppImage 可执行权限
sudo chmod +x navicat15-premium-cs.AppImage
# 启动navicat
./navicat15-premium-cs.AppImage
此时,点击注册然后进行下面的步骤
然后,重要的事情说三遍!
断开网络!
断开网络!
断开网络!
六、使用 navicat-keygen 来生成序列号和激活码
# 注:若第二、2步make all执行完毕且无误后,会在 navicat-keygen-tools/bin/ 文件夹下看到编译后的navicat-keygen
# Usage:
# <必填参数,生成的许可的格式,默认text>
# <--bin|--text> Specify "--bin" to generate "license_file" used by Navicat 11.
# Specify "--text" to generate base64-encoded activation code.
# This parameter must be specified.
#
# [--adv] Enable advance mode.
# This parameter is optional.
# <必填参数,rsa私钥文件路径,即:navicat-patcher生成的私钥文件路径>
# <RSA-2048 Private Key File> A path to an RSA-2048 private key file.
# This parameter must be specified.
# 例:navicat-keygen <--bin|--text> [--adv] <RSA-2048 Private Key File>
# navicat-keygen 在第三步 navicat-keygen-tools/bin里面
./bin/navicat-keygen --text ./RegPrivateKey.pem
下面是正确执行navicat-keygen后的样例输出
**********************************************************
* Navicat Keygen (Linux) by @DoubleLabyrinth *
* Version: 1.0 *
**********************************************************
[*] Select Navicat product:
0. DataModeler
1. Premium
2. MySQL
3. PostgreSQL
4. Oracle
5. SQLServer
6. SQLite
7. MariaDB
8. MongoDB
9. ReportViewer
# 根据你下的版本输入前面的序号
(Input index)> 1
[*] Select product language:
0. English
1. Simplified Chinese 这个是简体中文
2. Traditional Chinese
3. Japanese
4. Polish
5. Spanish
6. French
7. German
8. Korean
9. Russian
10. Portuguese
# 选择你需要的语言
(Input index)> 1
# 输入你下载的版本号
[*] Input major version number:
(range: 0 ~ 15, default: 12)> 15
# 将下面的序列号复制到navicat中,然后点击手动激活(如果没有手动激活,那就是你没断网!)
[*] Serial number:
NAVN-TK3I-HR6X-4SXP
# 随意输入你的姓名
[*] Your name: xxxxxxxx
# 你的组织
[*] Your organization: xxxxxxxx
# 将上面点手动激活后出现的请求码粘贴到这里,然后按两次回车
[*] Input request code in Base64: (Double press ENTER to end)
HHo8EXD/i76GstfRzrX2Kyz9/zmwJ31eM1AaRe7RGOOBbZZ4oI503okk8v8p+Z7BBX9SFJRMEKzqTXq2PBvIOauMsrgXIf............................
<!-- 此处省略若干 -->
/9c/CuQ3c3/lPR5/Vhtxnp3hgOYXxfSFnJeZYtva04MWmLyQhnWhX7oGlZr7/A==
[*] Request Info:
{"K":"NAVNTK3IHR6X4SXP", "DI":"68E8FB6311872482BEAA", "P":"linux"}
[*] Response Info:
{"K":"NAVNTK3IHR6X4SXP","DI":"68E8FB6311872482BEAA","N":"xxxxxxxx","O":"xxxxxxxx","T":1580149013}
# 把这下面的激活码复制到navicat下面的空白处,然后点激活~
# 到此你就会看到折腾这么久最终的成果~
[*] Activation Code:
ZW9RMt/uM2HGMh2AoQXx6wfHA4Br9CfjJNblUhQEMam4i+8RA/PNN8i5obx7pHTLmRg1FuToiGtUyE450NhEL29Oi3C
<!-- 此处省略若干 -->
ASY5LDdAJ4t5WNV2twvGgKeHTQNpLv17ldIKrL6tT/drVpUSMHdJ3xz+CkoCLzLQdxFDRA==