striderwhite/encryptable
最新稳定版本:v1.0.0
Composer 安装命令:
composer require striderwhite/encryptable
包简介
A Laravel trait for encrypting and decrypting model attributes using MySQL AES encryption.
README 文档
README
A Laravel trait for automatically encrypting and decrypting model attributes using MySQL AES encryption.
✨ Features:
- Models attributes that are marked as
encryptablewill automatically be AES encrypted upon persisting to the database. - Attributes are automatically decrypted upon retrieval via Eloquent model attributes or when serializing to JSON/array.
- Provides query builder helper methods for searching on the fields using Eloquent, supports both full and partial searching.
🚀 Installation
Install the package via Composer:
composer require striderwhite/encryptable
📖 Usage
- Database Setup: Ensure the database column you wish to encrypt is of
binarydatatype. - Add the Trait: Add the
Encryptabletrait to your Eloquent model. - Define Encryptable Fields: Define an
$encryptableproperty in your model with the list of attributes to encrypt.
use StriderWhite\Encryptable; class YourModel extends Model { use Encryptable; protected $encryptable = ['field1', 'field2']; }
- 💾 Persisting and Retrieving Data
Using the Encryptable trait, you can persist and retrieve data just like normal Eloquent attributes. The encryption and decryption process is handled automatically.
Example
use App\Models\YourModel; // Persisting data $model = new YourModel(); $model->field1 = 'Sensitive Data'; $model->field2 = 'Another Secret'; $model->save(); // Retrieving data $retrievedModel = YourModel::find($model->id); echo $retrievedModel->field1; // Outputs: Sensitive Data echo $retrievedModel->field2; // Outputs: Another Secret
🔎 Searching Encrypted Fields
The package provides two query scopes for searching encrypted fields:
scopeWhereEncrypted
Use this scope to search for an exact match on an encrypted field:
YourModel::whereEncrypted('field1', 'value')->get();
scopeWhereEncryptedLike
Use this scope to perform a partial search on an encrypted field:
YourModel::whereEncryptedLike('field1', 'value')->get();
🙏 Credits
Developed and maintained by Strider White. If you find this package helpful, feel free to ⭐ the repository or contribute!
📜 License
This package is open-sourced software licensed under the MIT license.
统计信息
- 总下载量: 2
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 5
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2025-04-12