2023-09-13 10:42:32 +08:00
|
|
|
|
ESP x509 证书包
|
|
|
|
|
===================
|
|
|
|
|
|
|
|
|
|
:link_to_translation:`en:[English]`
|
|
|
|
|
|
|
|
|
|
概述
|
|
|
|
|
-----
|
|
|
|
|
|
|
|
|
|
ESP x509 证书包 API 提供了一种简便的方法,帮助你安装自定义 x509 根证书用于 TLS 服务器验证。
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
|
|
目前在使用 WolfSSL 时该证书包不可用。
|
|
|
|
|
|
|
|
|
|
该证书包中包括 Mozilla NSS 根证书存储区的完整根证书列表。使用 gen_crt_bundle.py python 程序,可将证书的主题名称和公钥存储在文件中,并嵌入 {IDF_TARGET_NAME} 二进制文件。
|
|
|
|
|
|
|
|
|
|
生成证书包时,你需选择:
|
|
|
|
|
|
|
|
|
|
* 来自 Mozilla 的完整根证书包,包含超过 130 份证书。目前提供的证书包更新于 2023 年 1 月 10 日,星期二,04:12:06 (GMT)。
|
|
|
|
|
* 一组预先筛选的常用根证书。其中仅包含约 41 份证书,但根据 SSL 证书颁发机构统计数据,其绝对使用率约达到 90%,市场覆盖率约达 99%。
|
|
|
|
|
|
|
|
|
|
此外,还可指定证书文件的路径或包含证书的目录,将其他证书添加到生成的证书包中。
|
|
|
|
|
|
|
|
|
|
.. note::
|
|
|
|
|
|
|
|
|
|
信任所有根证书意味着如果任何证书被收回,就必须更新证书列表,包括从 ``cacrt_all.pem`` 中将其删除。
|
|
|
|
|
|
|
|
|
|
配置
|
|
|
|
|
------
|
|
|
|
|
|
|
|
|
|
多数配置可通过 menuconfig 完成。CMake 会根据配置信息生成及嵌入证书包。
|
|
|
|
|
|
|
|
|
|
* :ref:`CONFIG_MBEDTLS_CERTIFICATE_BUNDLE`:自动创建并附加证书包。
|
|
|
|
|
* :ref:`CONFIG_MBEDTLS_DEFAULT_CERTIFICATE_BUNDLE`:决定添加证书列表中的哪些证书。
|
|
|
|
|
* :ref:`CONFIG_MBEDTLS_CUSTOM_CERTIFICATE_BUNDLE_PATH`:指定要在证书包中嵌入的其他证书的路径。
|
|
|
|
|
|
|
|
|
|
要在使用 ESP-TLS 时启用证书包,将函数指针指向证书包的 attach 函数:
|
|
|
|
|
|
|
|
|
|
.. code-block:: c
|
|
|
|
|
|
|
|
|
|
esp_tls_cfg_t cfg = {
|
|
|
|
|
.crt_bundle_attach = esp_crt_bundle_attach,
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
此步骤是为了避免在用户未使能的情况下嵌入证书包。
|
|
|
|
|
|
|
|
|
|
如果直接使用 mbedTLS 包,在设置阶段直接调用 attach 函数可以激活证书包:
|
|
|
|
|
|
|
|
|
|
.. code-block:: c
|
|
|
|
|
|
|
|
|
|
mbedtls_ssl_config conf;
|
|
|
|
|
mbedtls_ssl_config_init(&conf);
|
|
|
|
|
|
|
|
|
|
esp_crt_bundle_attach(&conf);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
.. _updating_bundle:
|
|
|
|
|
|
|
|
|
|
生成根证书列表
|
|
|
|
|
----------------
|
|
|
|
|
|
|
|
|
|
根证书列表来自 Mozilla 的 `NSS 根证书商店 <https://wiki.mozilla.org/CA/Included_Certificates>`_。
|
|
|
|
|
|
|
|
|
|
运行 ``mk-ca-bundle.pl`` 脚本可下载和创建列表。脚本发布于 `curl <https://github.com/curl/curl>`_。
|
|
|
|
|
|
|
|
|
|
还可通过 curl 网站直接下载完整列表: `从 Mozilla 提取的 CA 证书 <https://curl.se/docs/caextract.html>`_。
|
|
|
|
|
|
|
|
|
|
常用证书包是通过筛选出市场份额超过 1% 的授权机构来决定的,筛选数据来自 w3tech 的 `SSL Survey <https://w3techs.com/technologies/overview/ssl_certificate>`_。
|
|
|
|
|
|
|
|
|
|
根据这些授权机构,从 Mozilla 提供的 `列表 <https://ccadb-public.secure.force.com/mozilla/IncludedCACertificateReportPEMCSV>`_ 的 ``cmn_crt_authorities.csv`` 中筛选证书名称。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
更新证书包
|
|
|
|
|
------------
|
|
|
|
|
|
|
|
|
|
证书包嵌入到应用程序中,通过 OTA 更新与应用程序一起更新。如果想使用比目前 ESP-IDF 中的证书包更新的包,则可按照 :ref:`updating_bundle` 中的说明从 Mozilla 下载证书列表。
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
应用示例
|
|
|
|
|
---------
|
|
|
|
|
|
|
|
|
|
使用 ESP-TLS 创建安全套接字连接的简单 HTTPS 示例::example:`protocols/https_x509_bundle`,该示例使用了证书包并添加了两个自定义证书用于验证。
|
|
|
|
|
|
|
|
|
|
使用 ESP-TLS 和默认证书包的 HTTPS 示例::example:`protocols/https_request`。
|
|
|
|
|
|
|
|
|
|
使用 mbedTLS 和默认证书包的 HTTPS 示例::example:`protocols/https_mbedtls`。
|
|
|
|
|
|
|
|
|
|
API 参考
|
|
|
|
|
----------
|
|
|
|
|
|
|
|
|
|
.. include-build-file:: inc/esp_crt_bundle.inc
|