PHP Conference Japan 2024

sodium_crypto_aead_aes256gcm_is_available

(PHP 7 >= 7.2.0, PHP 8)

sodium_crypto_aead_aes256gcm_is_available检查硬件是否支持 AES256-GCM

描述

sodium_crypto_aead_aes256gcm_is_available(): bool

此函数的返回值取决于硬件是否支持硬件加速的 AES。

参数

此函数没有参数。

返回值

如果使用 AES-256-GCM 加密是安全的,则返回 true,否则返回 false

添加注释

用户贡献的注释 1 条注释

Soatok Dreamseeker
3 年前
libsodium 为 AES-GCM 而不是 ChaCha-Poly AEAD 密码提供“is_available()”API 的原因是,与 OpenSSL 不同,libsodium 不会公开 AES-GCM,除非您的处理器支持硬件加速的 AES 和 PCLMULQDQ 指令。

如果您想知道这意味着什么:软件 AES 容易受到缓存定时漏洞的影响,因为它内部依赖于查找表:https://cr.yp.to/antiforgery/cachetiming-20050414.pdf (PDF)

GCM 中的身份验证步骤也存在类似的攻击(根据上下文称为 GMAC 或 GHASH),它会泄露 GHASH 密钥(称为 H),并可用于自由执行选择密文攻击。

- 您可以在此处了解有关 GCM 利用的更多信息(在 nonce 重用而不是定时泄露的条件下,但结果相同):https://www.youtube.com/watch?v=uxuXFK5XKEU

- 您可以在此处了解有关 AES-GCM 的更多信息:https://soatok.blog/2020/05/13/why-aes-gcm-sucks/

- 您可以在此处了解有关它与其他加密模式的比较:https://soatok.blog/2020/07/12/comparison-of-symmetric-encryption-methods/

其他 AEAD 模式可以在软件中安全地实现,而无需担心侧信道泄露。

要点是:AES-GCM 并非在所有硬件上都保证可用,因为如果没有硬件支持,libsodium 将不会提供不安全的实现。

如果您希望即使在无法控制的硬件上(您好,开源维护者)也保证可用,您的选择是 ChaCha20-Poly1305 和 XChaCha20-Poly1305。

如果您能够控制硬件并明确需要 AES-GCM(例如,用于 FIPS 140-2 认证),请随意使用 AES-256-GCM。

<?php
function do_something(string $message, CryptoKeyObject $key): string {
if (!
sodium_crypto_aead_aes256gcm_is_available()) {
throw new
Exception("AES-256-GCM 在您的硬件上不可用");
}
// ... 您的代码在此处 ...
}
?>
To Top