lingyun / think-encryption
ThinkPHP6 加密包。
v1.0.0
2023-09-23 16:17 UTC
Requires
- ext-hash: *
- ext-mbstring: *
- ext-openssl: *
- topthink/framework: ^6.0||^8.0
This package is auto-updated.
Last update: 2024-09-24 19:24:13 UTC
README
介绍
ThinkPHP的加密服务通过OpenSSL使用AES-256和AES-128加密,提供了一个简单、方便的接口来加密和解密文本。
安装
您可以通过Composer包管理器安装 think-encryption。
composer require lingyun/think-encryption
配置
在使用ThinkPHP的加密器之前,您必须在您的 config/encrypter.php 配置文件中设置 key 配置选项。此配置值由 ENCRYPTER.KEY 环境变量驱动。您应该使用 php think encrypter:generate 命令生成此变量的值,因为 key:generate 命令将使用PHP的安全随机字节生成器为您构建一个加密密钥。
使用加密器
加密一个值
您可以使用 Crypt 门面的 encryptString 方法加密一个值。所有加密的值都使用OpenSSL和AES-256-CBC加密算法加密。此外,所有加密的值都使用消息认证码(MAC)签名。集成的消息认证码将防止任何被恶意用户篡改的值的解密。
use think\facade\Crypt;
use think\encryption\exception\EncryptException;
try {
$encrypted = Crypt::encryptString($valueToBeEncrypted);
} catch (EncryptException $e) {
//
}
解密一个值
您可以使用 Crypt 门面的 decryptString 方法解密值。如果值无法正确解密,例如当消息认证码无效时,将抛出 think\encryption\exception\DecryptException。
use think\encryption\exception\DecryptException;
use think\facade\Crypt;
try {
$decrypted = Crypt::decryptString($encryptedValue);
} catch (DecryptException $e) {
//
}