mmeyer2k/php-aes-gcm
Composer 安装命令:
composer require mmeyer2k/php-aes-gcm
包简介
README 文档
README
A compact and foolproof AES-256 GCM implementation for PHP powered by ext-sodium.
On systems without AES-NI support, this library falls back to using ext-openssl.
Data encryption is cross-compatible between both extensions.
Install
To take advantage of the cool features in PHP 8.2+, install from the main branch.
composer require "mmeyer2k/php-aes-gcm:dev-main"
Basic usage
$key = '\+YoUr\+32\+ByTe\+BaSe64\+EnCoDeD\+kEy\+GoEs\+HeRe\+'; $msg = 'Hello World!'; $aes = new \Mmeyer2k\AesGcm\AesGcm($key); $enc = $aes->encrypt($msg); $dec = $aes->decrypt($enc); echo $dec;
Keys
This library expects 32 byte keys encoded with base64. Keys should originate from secure sources of randomness to ensure the highest degree of protection.
In PHP:
echo base64_decode(random_bytes(32));
In BaSH:
head -c 32 /dev/urandom | base64 -w 0 | xargs echo
Other Usages
Additional Authenticated Data (AAD)
AAD data is extra information that is authenticated but unencrypted. Both the AAD and ciphertext must be present for decryption to proceed.
$aes = new \Mmeyer2k\AesGcm\AesGcm($key); $aad = '...some extra information...' $enc = $aes->encrypt($msg, $aad); $dec = $aes->decrypt($enc, $aad);
Native Key Rotation
To rotate keys, pass an array of key strings into the constructor. The first key (index 0) will be used for encryption. All keys will be attempted when decrypting.
$old = [ 'key 1', 'key 2', 'key 3', ]; $aes = new \Mmeyer2k\AesGcm\AesGcm($keys); $dec = $aes->decrypt($ciphertext);
统计信息
- 总下载量: 10
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2024-05-31