如何使用Mkchain构建一个有效的SSL证书链

admin 2023年10月30日01:55:08评论4 views字数 2338阅读7分47秒阅读模式
如何使用Mkchain构建一个有效的SSL证书链


如何使用Mkchain构建一个有效的SSL证书链


 关于Mkchain 


Mkchain是一款功能强大的开源安全工具,在该工具的帮助下,广大研究人员可以轻松构建一个有效的SSL证书链。除此之外,该工具还可以帮助我们修复不完整的SSL证书链或下载所有缺失的CA证书。我们甚至还可以利用该工具从远程服务器下载所有的证书,以修复你自己的证书链。


 工具要求 


当前版本的Mkchain需要使用到下列外部实用工具:


OpenSSL(v1.10g/h)

GNU/Linux(Debian或CentOS)

Bash(v4.4.19)


 工具下载 


首先,广大研究人员可以使用下列命令将该项目源码克隆至本地:

git clone https://github.com/trimstray/mkchain


然后切换到项目目录中,执行工具安装脚本:

./setup.sh install

将指向bin/mkchain的符号连接移动到/usr/local/bin。


工具使用手册可以在/usr/local/man/man8中找到。


最后,使用下列命令即可开始使用Mkchain:

mkchain -i /data/certs -o /data/chain.crt


 工具参数 


该工具提供了下列运行参数选项:

Usage:
mkchain <option|long-option>


Options:
--help 显示工具帮助信息和退出
--debug 在屏幕上显示调试信息(调试模式)
-i, --in 添加要整合的证书(单/多文件、包含SSL证书的目录或远程域名)
-o, --out 将所有的结果(证书链)存储到文件中
--with-root 将根证书添加到证书链

(向右滑动,查看更多)


 工具运行机制 


我们以ssllabs证书链为例,mkchain项目中提供了一个example/ssllabs.com目录,其中有一个all目录(该目录中包含了构建证书链所需要的全部证书)和server_certificate目录(仅包含服务器证书)。

ssllabs.com域名的正确证书链(openssl命令结果):


Certificate chain
0 s:/C=US/ST=California/L=Redwood City/O=Qualys, Inc./CN=ssllabs.com
i:/C=US/O=Entrust, Inc./OU=See www.entrust.net/legal-terms/OU=(c) 2012 Entrust, Inc. - for authorized use only/CN=Entrust Certification Authority - L1K
1 s:/C=US/O=Entrust, Inc./OU=See www.entrust.net/legal-terms/OU=(c) 2012 Entrust, Inc. - for authorized use only/CN=Entrust Certification Authority - L1K
i:/C=US/O=Entrust, Inc./OU=See www.entrust.net/legal-terms/OU=(c) 2009 Entrust, Inc. - for authorized use only/CN=Entrust Root Certification Authority - G2
2 s:/C=US/O=Entrust, Inc./OU=See www.entrust.net/legal-terms/OU=(c) 2009 Entrust, Inc. - for authorized use only/CN=Entrust Root Certification Authority - G2
   i:/C=US/O=Entrust, Inc./OU=www.entrust.net/CPS is incorporated by reference/OU=(c) 2006 Entrust, Inc./CN=Entrust Root Certification Authority

(向右滑动,查看更多)


场景一


在这个场景中,我们将链接所有证书:


如何使用Mkchain构建一个有效的SSL证书链


场景二


在这个场景中,我们只会使用服务器证书,并用它来获取剩余所需的证书,然后将所有的证书链接:


如何使用Mkchain构建一个有效的SSL证书链


证书路径


Mkchain允许使用两种证书路径:


如何使用Mkchain构建一个有效的SSL证书链


 工具使用样例 


mkchain --in Root.crt --in Intermediate1.crt --in Server.crt --out bundle_chain_certs.crt

mkchain --in /tmp/certs --out bundle_chain_certs.crt --with-root

mkchain -i Server.crt -o bundle_chain_certs.crt

mkchain -i https://incomplete-chain.badssl.com/ --with-root


许可证协议


本项目的开发与发布遵循GPL-3.0开源许可证协议。


 项目地址 


Mkchain

https://github.com/trimstray/mkchain


FreeBuf粉丝交流群招新啦!

在这里,拓宽网安边界

甲方安全建设干货;

乙方最新技术理念;

全球最新的网络安全资讯;

群内不定期开启各种抽奖活动;

FreeBuf盲盒、大象公仔......

扫码添加小蜜蜂微信回复“加群”,申请加入群聊

如何使用Mkchain构建一个有效的SSL证书链


如何使用Mkchain构建一个有效的SSL证书链
如何使用Mkchain构建一个有效的SSL证书链

https://medium.com/@superseb/get-your-certificate-chain-right-4b117a9c0fce

https://support.dnsimple.com/articles/what-is-ssl-certificate-chain/

如何使用Mkchain构建一个有效的SSL证书链

如何使用Mkchain构建一个有效的SSL证书链

如何使用Mkchain构建一个有效的SSL证书链

如何使用Mkchain构建一个有效的SSL证书链

如何使用Mkchain构建一个有效的SSL证书链

原文始发于微信公众号(FreeBuf):如何使用Mkchain构建一个有效的SSL证书链

  • 左青龙
  • 微信扫一扫
  • weinxin
  • 右白虎
  • 微信扫一扫
  • weinxin
admin
  • 本文由 发表于 2023年10月30日01:55:08
  • 转载请保留本文链接(CN-SEC中文网:感谢原作者辛苦付出):
                   如何使用Mkchain构建一个有效的SSL证书链http://cn-sec.com/archives/2154517.html

发表评论

匿名网友 填写信息