這篇文章給大家分享一個Laravel擴充推薦:Ciphersweet套件(加密/解密欄位)擴充:Ciphersweet包,介紹一下怎麼利用Laravel擴充推薦:Ciphersweet套件(加密/解密欄位) Ciphersweet 來加密/解密 Laravel擴充推薦:Ciphersweet套件(加密/解密欄位) 中的 Eloquent 模型字段,希望對大家有所幫助!
Laravel擴充推薦:Ciphersweet套件(加密/解密欄位) Ciphersweet# 是由 Spatie 提供的一個包,用於在Laravel擴充推薦:Ciphersweet套件(加密/解密欄位)應用程式中整合可搜尋的字段級加密。該套件的 readme 解釋了密碼甜蜜可以幫助解決的問題,如下所示:
在你的專案中,你可能會將敏感的個人資料儲存在資料庫中。如果未經授權的人存取你的資料庫,則所有敏感資料都可以讀取,這顯然是不好的。
要解決這個問題,你可以對個人資料進行加密。這樣,未經授權的人無法讀取它,但當你需要顯示或使用資料時,你的應用程式仍然可以解密它。
這個套件是 Ciphersweet 的包裝器,可以輕鬆地將其功能整合到 Laravel擴充推薦:Ciphersweet套件(加密/解密欄位) 模型中。以下是自述文 setup instructions 中的模型範例,該範例說明了使用Ciphersweet 模型的外
use Spatie\Laravel擴充推薦:Ciphersweet套件(加密/解密欄位)CipherSweet\Contracts\CipherSweetEncrypted; use Spatie\Laravel擴充推薦:Ciphersweet套件(加密/解密欄位)CipherSweet\Concerns\UsesCipherSweet; use ParagonIE\CipherSweet\EncryptedRow; use Illuminate\Database\Eloquent\Model; class User extends Model implements CipherSweetEncrypted { use UsesCipherSweet; public static function configureCipherSweet(EncryptedRow $encryptedRow): void { $encryptedRow ->addField('email') ->addBlindIndex('email', new BlindIndex('email_index')); } }
這允許你加密使用者的電子郵件,以防止未經授權的人讀取數據,但允許你解密數據以顯示或使用它。
一旦你配置了此套件並設定了模型,你就可以使用盲索引在資料庫中搜尋加密資料:
$user = User::whereBlind('email', 'email_index', 'rias@spatie.be');
此套件還有助於產生加密金鑰和加密模型屬性,以加快與密碼的整合。
我想指出的是,你不應該在不了解你試圖解決的用例的來龍去脈的情況下盲目地使用這個套件。你可以在此頁面 上了解有關CipherSweet 的更多信息,其中包含許多鏈接資源
CipherSweet 還具有PHP 特定文檔 可幫助您快速了解底層PHP包。
我還建議閱讀 Rias 的帖子,使用 CipherSweet 加密 Laravel擴充推薦:Ciphersweet套件(加密/解密欄位) Eloquent 模型。
要開始使用這個包,請在 GitHub 上的 spatie/laravel-ciphersweet 上查看它。
本文中的所有翻譯僅用於學習和溝通目的,轉載請務必註明文章譯者、來源、和本文連結
我們的翻譯中遵循 CC 協定時,如果我們的工作侵犯於您的權益,請及時聯絡我們。
原文網址:https://laravel-news.com/laravel-ciphers...
翻譯網址:https ://www.php.cn/link/53701130ff29be387e2fa7e04928b5ed
以上是Laravel擴充推薦:Ciphersweet套件(加密/解密欄位)的詳細內容。更多資訊請關注PHP中文網其他相關文章!