AES-256-GCM 在 M1 Macbook 上的 PHP ext-sodium 中不可用

问题描述

最近在工作中,我们有一个新员工参与我们的一个项目,该项目通过 PHP 的钠扩展利用 AES-256-GCM 加密和解密。由于我们都使用 Macbook,新员工收到了一台 2020 款配备 M1 芯片的 Macbook Pro。

启动和运行上述项目的第一次尝试是使用 HomeBrew 设置,它运行以下组件:

我们很快注意到 <!DOCTYPE html> {% load static %} <html lang="en"> <head> <Meta charset="UTF-8"> <Meta http-equiv="X-UA-Compatible" content="IE=edge"> <Meta name="viewport" content="width=device-width,initial-scale=1.0"> <title>Blood Donation</title> <!-- Latest compiled and minified CSS --> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0/css/bootstrap.min.css" integrity="sha384-Gn5384xqQ1aoWXA+058RXPxPg6fy4IWvTNh0E263XmFcJlSAwiGgFAW/dAiS6JXm" crossorigin="anonymous"> <link rel="stylesheet" href="{% static 'css/master.css'%}"> </head> <body> <nav class="navbar navbar-expand-lg navbar-light bg-light navbar-static-top"> <div class="container"> <a class="navbar-brand" href="{% url 'index' %}">Blood<span>Donation</span></a> <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation"> <span class="navbar-toggler-icon"></span> </button> <div class="collapse navbar-collapse" id="navbarSupportedContent"> <ul class="navbar-nav mr-auto"> <li class="nav-item item-one active"> <a class="nav-link" href="{% url 'index' %}">Home <span class="sr-only">(current)</span></a> </li> <li class="nav-item"> <a class="nav-link" href="#">Search</a> </li> <li class="nav-item"> <a class="nav-link" href="#">Contact Us</a> </li> </ul> <div class=""> <ul class="navbar-nav ml-auto"> <!-- <li class="nav-item"><a class="nav-link" href="{% url 'basic_app:register' %}">Register</a></li> --> {% if user.is_authenticated %} <li class="nav-item"><a class="nav-link" href="{% url 'basic_app:profile' pk=user.id %}">Profile</a></li> <li class="nav-item"><a class="nav-link" href="{% url 'logout' %}">logout</a></li> {% else %} <li class="nav-item"><a class="nav-link" href="{% url 'basic_app:register' %}">Register</a></li> <li class="nav-item"><a class="nav-link" href="{% url 'basic_app:user_login' %}">Login</a></li> {% endif %} </ul> </div> </div> </div> </nav> <div class="container"> {% block body_block %} {% endblock %} </div> </body> </html> 在我们的代码中返回 false,表明 Macbook 的硬件不支持 AES-256-GCM。另一方面,运行 sodium_crypto_aead_aes256gcm_is_available() 给了我们这个列表:

openssl list-cipher-algorithms | grep "GCM"

运行 id-aes128-GCM id-aes192-GCM id-aes256-GCM id-aes128-GCM id-aes192-GCM id-aes256-GCM 也返回了预期的输出,所以 openssl 似乎可以访问/能够使用它。

openssl speed -elapsed -evp aes-256-gcm

使用该项目的 dockerized 版本的第二次尝试产生了相同的结果,并且还声称带有 AEAD 的 AES-256-GCM 不受硬件支持,这是意料之中的,因为它在相同的主机硬件上运行。这是使用来自 dockerhub 的官方 PHP 7.4 映像完成的。

关于 M1 芯片、AES-256-GCM 使用 (lib)sodiumPHP 的组合是否存在任何已知问题?我们花了几天时间在这里支持板上搜索,但这种组合似乎非常小众。目前,我建议每个开发人员都继续使用基于 Intel 的 Macbook,因为该平台上的一切都是开箱即用的。

到目前为止,我们已经检查了以下内容

  • PHP 中启用了 ext-sodium?是的
  • 它可以在使用 HomeBrew 的基于 Intel 的 Macbook Pro 上运行吗?是的
  • 它是否适用于使用 Docker (compose) 的基于 Intel 的 Macbook Pro?是的
  • OpenSSL 是否支持 AES-256-GCM?是的

解决方法

在 Apple 支持论坛上的 further inquiry 之后,他们向我指出了 libsodium 中没有完全提供 ARM 硬件加速支持的方向。一个名为 Support for AES and GCM instructions on ARM processors #363 的 GitHub 问题进一步表明,鉴于该问题于 2016 年开放并于 2018 年突然关闭,似乎短期内没有立即执行此操作的计划。

如果您的项目将在任何地方开发或将在 ARM 架构上运行,我目前建议将 OpenSSL 用于 AES-256-GCM。他们似乎已经为 ARM 环境实现了硬件加速。

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...