mbedtls.rst 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. Mbed TLS
  2. ========
  3. :link_to_translation:`en:[English]`
  4. `Mbed TLS <https://github.com/Mbed-TLS/mbedtls>`_ 是一个 C 代码库,用于实现加密基元、X.509 证书操作以及 SSL/TLS 和 DTLS 协议。该库代码占用空间小,适合嵌入式系统使用。
  5. .. note::
  6. ESP-IDF 使用的 Mbed TLS `复刻仓库 <https://github.com/espressif/mbedtls>`_ 中包含对原生 Mbed TLS 的补丁。这些补丁与某些模块的硬件例程有关,如 ``bignum (MPI)`` 和 ``ECC``。
  7. Mbed TLS 提供以下功能:
  8. - TCP/IP 通信功能:监听、连接、接收、读/写。
  9. - SSL/TLS 通信功能:初始化、握手、读/写。
  10. - X.509 功能:CRT、CRL 和密钥处理
  11. - 随机数生成
  12. - 哈希
  13. - 加密/解密
  14. TLS 版本支持 SSL 3.0, TLS 1.0、TLS 1.1、TLS 1.2 和 TLS 1.3,但是最新的 ESP-IDF 上 Mbed TLS 已经移除了 SSL 3.0、TLS 1.0 和 TLS 1.1。DTLS 版本支持 DTLS 1.0、DTLS 1.1 和 DTLS 1.2,但最新的 ESP-IDF 上 Mbed TLS 已经移除了 DTLS 1.0。
  15. Mbed TLS 文档
  16. ------------------
  17. Mbed TLS 文档请参阅以下(上游)指针:
  18. - `API Reference`_
  19. - `Knowledge Base`_
  20. ESP-IDF 的 Mbed TLS 支持
  21. ------------------------------
  22. 请在 `此处 <https://github.com/espressif/mbedtls/wiki#mbed-tls-support-in-esp-idf>`__ 查找 ESP-IDF 不同分支上的 Mbed TLS 版本信息。
  23. .. note::
  24. 参考 :ref:`migration_guide_mbedtls` 从 Mbed TLS 2.x 版本迁移到 3.0 及以上版本。
  25. 应用示例
  26. -------------
  27. ESP-IDF 中的示例使用 :doc:`/api-reference/protocols/esp_tls`,为访问常用的 TLS 功能提供了一个简化 API 接口。
  28. 参考示例 :example:`protocols/https_server/simple` (简单的 HTTPS 服务器)和 :example:`protocols/https_request` (发出 HTTPS 请求)了解更多信息。
  29. 如需直接使用 Mbed TLS API,请参考示例 :example:`protocols/https_mbedtls`。
  30. 其他选项
  31. ----------
  32. :doc:`/api-reference/protocols/esp_tls` 是底层 SSL/TLS 库的抽象层,因此可以选择使用 Mbed TLS 或 wolfSSL 作为底层库。默认情况下,仅 Mbed TLS 可在 ESP-IDF 中使用,而 wolfSSL 在 `<https://github.com/espressif/esp-wolfSSL>`_ 公开,还提供了上游子模块指针的相关信息。
  33. 如需了解更多相关信息或比较 Mbed TLS 和 wolfSSL,请参考文档 :ref:`ESP-TLS: Underlying SSL/TLS Library Options <esp_tls_wolfssl>`。
  34. 重要配置
  35. -------------
  36. ``Component Config -> mbedTLS`` 中的部分重要配置选项如下表所示。点击 :ref:`此处 <CONFIG_MBEDTLS_MEM_ALLOC_MODE>` 获取完整配置选项列表。
  37. .. list::
  38. - :ref:`CONFIG_MBEDTLS_SSL_PROTO_TLS1_2`: 支持 TLS 1.2
  39. - :ref:`CONFIG_MBEDTLS_SSL_PROTO_TLS1_3`: 支持 TLS 1.3
  40. - :ref:`CONFIG_MBEDTLS_CERTIFICATE_BUNDLE`: 支持受信任的根证书包(更多信息请参考 :doc:`/api-reference/protocols/esp_crt_bundle`)
  41. - :ref:`CONFIG_MBEDTLS_CLIENT_SSL_SESSION_TICKETS`: 支持 TLS 会话恢复:客户端会话票证
  42. - :ref:`CONFIG_MBEDTLS_SERVER_SSL_SESSION_TICKETS`: 支持 TLS 会话恢复:服务会话票证
  43. - :ref:`CONFIG_MBEDTLS_HARDWARE_SHA`: 支持硬件 SHA 加速
  44. :SOC_AES_SUPPORTED: - :ref:`CONFIG_MBEDTLS_HARDWARE_AES`: 支持硬件 AES 加速
  45. :SOC_MPI_SUPPORTED: - :ref:`CONFIG_MBEDTLS_HARDWARE_MPI`: 支持硬件 MPI (bignum) 加速
  46. :SOC_ECC_SUPPORTED: - :ref:`CONFIG_MBEDTLS_HARDWARE_ECC`: 支持硬件 ECC 加速
  47. .. note::
  48. Mbed TLS v3.0.0 及其更新版本仅支持 TLS 1.2 和 TLS 1.3,不支持 SSL 3.0、TLS 1.0、TLS 1.1、和 DTLS 1.0)。TLS 1.3 尚在试验阶段,仅支持客户端。要了解更多信息,请点击 `此处 <https://github.com/espressif/mbedtls/blob/9bb5effc3298265f829878825d9bd38478e67514/docs/architecture/tls13-support.md>`__。
  49. 性能和内存调整
  50. ------------------
  51. .. _reducing_ram_usage_mbedtls:
  52. 减少内存使用
  53. ^^^^^^^^^^^^^^^^^
  54. 下表展示了在不同配置下,用 Mbed TLS 作为 SSL/TLS 库运行示例 :example:`protocols/https_request` (启用服务器验证)时,内存的实际使用情况。
  55. .. list-table::
  56. :header-rows: 1
  57. :widths: 25 60 30
  58. :align: center
  59. * - Mbed TLS 测试
  60. - 相关配置
  61. - 堆使用(近似)
  62. * - 默认
  63. - NA
  64. - 42196 B
  65. * - 启用 SSL 动态 buffer 长度
  66. - :ref:`CONFIG_MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH`
  67. - 42120 B
  68. * - 禁用保留对端证书
  69. - :ref:`CONFIG_MBEDTLS_SSL_KEEP_PEER_CERTIFICATE`
  70. - 38533 B
  71. * - 启用动态 buffer 功能
  72. - :ref:`CONFIG_MBEDTLS_DYNAMIC_BUFFER`
  73. :ref:`CONFIG_MBEDTLS_DYNAMIC_FREE_CONFIG_DATA`
  74. :ref:`CONFIG_MBEDTLS_DYNAMIC_FREE_CA_CERT`
  75. - 22013 B
  76. .. note::
  77. 这些值会随着配置选项和 Mbed TLS 版本的变化而变化。
  78. 减小固件大小
  79. ^^^^^^^^^^^^^^^^^^^^
  80. 在 ``Component Config -> mbedTLS`` 中,有多个 Mbed TLS 功能默认为启用状态。如果不需要这些功能,可将其禁用以减小固件大小。要了解更多信息,请参考 :ref:`Minimizing Binary Size <minimizing_binary_mbedtls>` 文档。
  81. .. _`API Reference`: https://mbed-tls.readthedocs.io/projects/api/en/v3.4.1/
  82. .. _`Knowledge Base`: https://mbed-tls.readthedocs.io/en/latest/kb/