简介

Laravel 的加密服务提供了一个简单、方便的接口,使用 OpenSSL 所提供的 AES-256 和 AES-128 加密和解密文本。所有 Laravel 加密的结果都会使用消息认证码 (MAC) 进行签名,因此一旦加密,其底层值就不能被修改或篡改。

配置

在使用 Laravel 的加密工具之前,你必须先设置 php config/app.php 配置文件中的 php key 配置项。该配置项由环境变量 php APP_KEY 设定。你应当使用 php php artisan key:generate 命令来生成该变量的值,php key:generate 命令将使用 PHP 的安全随机字节生成器为你的应用程序构建加密安全密钥。通常情况下,在 Laravel 安装 中会为你生成 APP_KEY 环境变量的值。

基本用法

加密一个值
你可以使用 php Crypt 门面提供的 php encryptString 方法来加密一个值。所有加密的值都使用 OpenSSL 的 AES-256-CBC 来进行加密。此外,所有加密过的值都会使用消息认证码 (MAC) 来签名,可以防止恶意用户对值进行篡改:

  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\User;
  5. use Illuminate\Http\RedirectResponse;
  6. use Illuminate\Http\Request;
  7. use Illuminate\Support\Facades\Crypt;
  8. class DigitalOceanTokenController extends Controller
  9. {
  10. /**
  11. * 为用户存储一个 DigitalOcean API 令牌。
  12. */
  13. public function store(Request $request): RedirectResponse
  14. {
  15. $request->user()->fill([
  16. 'token' => Crypt::encryptString($request->token),
  17. ])->save();
  18. return redirect('/secrets');
  19. }
  20. }

解密一个值
你可以使用 php Crypt 门面提供的 php decryptString 来进行解密。如果该值不能被正确解密,例如消息认证码 (MAC) 无效,会抛出异常 php Illuminate\Contracts\Encryption\DecryptException

  1. use Illuminate\Contracts\Encryption\DecryptException;
  2. use Illuminate\Support\Facades\Crypt;
  3. try {
  4. $decrypted = Crypt::decryptString($encryptedValue);
  5. } catch (DecryptException $e) {
  6. // ...
  7. }