加密
簡介
Laravel 的加密服務提供了一個簡單、方便的介面,用於透過 OpenSSL 使用 AES-256 和 AES-128 加密來加密和解密文字。所有 Laravel 的加密值都使用訊息驗證碼 (MAC) 進行簽署,這樣它們的基礎值一旦加密後就無法被修改或竄改。
設定
在使用 Laravel 的加密器之前,您必須在 config/app.php
設定檔中設定 key
設定選項。此設定值由 APP_KEY
環境變數驅動。您應該使用 php artisan key:generate
命令來產生此變數的值,因為 key:generate
命令將使用 PHP 的安全隨機位元組產生器來為您的應用程式建構一個密碼安全的金鑰。通常,APP_KEY
環境變數的值會在 Laravel 的安裝過程中為您產生。
優雅地輪換加密金鑰
如果您變更應用程式的加密金鑰,所有已驗證的使用者會話將會從您的應用程式中登出。這是因為每個 cookie,包括會話 cookie,都是由 Laravel 加密的。此外,也將無法再解密使用您先前的加密金鑰加密的任何資料。
為了減輕這個問題,Laravel 允許您在應用程式的 APP_PREVIOUS_KEYS
環境變數中列出您先前的加密金鑰。此變數可能包含一個以逗號分隔的所有先前加密金鑰的列表
APP_KEY="base64:J63qRTDLub5NuZvP+kb8YIorGS6qFYHKVo6u7179stY="APP_PREVIOUS_KEYS="base64:2nLsGFGzyoae2ax3EF2Lyq/hH6QghBGLIq5uL+Gp8/w="
當您設定這個環境變數時,Laravel 在加密值時會始終使用「當前」的加密金鑰。但是,當解密值時,Laravel 會先嘗試當前金鑰,如果使用當前金鑰解密失敗,Laravel 會嘗試所有先前的金鑰,直到其中一個金鑰能夠解密該值為止。
這種優雅解密的方法允許使用者即使在加密金鑰輪換時也能持續不間斷地使用您的應用程式。
使用加密器
加密值
您可以使用 Crypt
門面提供的 encryptString
方法來加密值。所有加密的值都使用 OpenSSL 和 AES-256-CBC 密碼加密。此外,所有加密的值都使用訊息驗證碼 (MAC) 進行簽署。整合的訊息驗證碼將防止解密任何被惡意使用者竄改的值
<?php namespace App\Http\Controllers; use Illuminate\Http\RedirectResponse;use Illuminate\Http\Request;use Illuminate\Support\Facades\Crypt; class DigitalOceanTokenController extends Controller{ /** * Store a DigitalOcean API token for the user. */ public function store(Request $request): RedirectResponse { $request->user()->fill([ 'token' => Crypt::encryptString($request->token), ])->save(); return redirect('/secrets'); }}
解密值
您可以使用 Crypt
門面提供的 decryptString
方法來解密值。如果無法正確解密該值,例如當訊息驗證碼無效時,將會拋出 Illuminate\Contracts\Encryption\DecryptException
例外
use Illuminate\Contracts\Encryption\DecryptException;use Illuminate\Support\Facades\Crypt; try { $decrypted = Crypt::decryptString($encryptedValue);} catch (DecryptException $e) { // ...}