上一章简单介绍了一下国密算法,本章开始进入实战,进行国密算法的移植。算法的移植以铜锁为蓝本,移植到 BoringSSL 中。
BoringSSL 也是由 OpenSSL fork 而来,那能否修改 Chromium 的源码,使用铜锁库呢?这种方式我也考虑并尝试过,最后发现两者的接口差别太大,Chromium Net 部分的代码写的很复杂,修改起来工作量更大,所以这里还是选择修改 BoringSSL,加入国密算法支持。
铜锁源码下载和编译
1. 代码下载
在产品中使用第三方库,通常不需要特别新的特性,所以最好选择稳定发布版本,这里选择铜锁的当前稳定发布版本 8.4.0。
可以直接下载源代码包:
wget https://github.com/Tongsuo-Project/Tongsuo/archive/refs/tags/8.4.0.tar.gz
也可以通过 git 命令克隆代码库,然后基于tag