striderwhite/encryptable 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

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 encryptable will 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

  1. Database Setup: Ensure the database column you wish to encrypt is of binary datatype.
  2. Add the Trait: Add the Encryptable trait to your Eloquent model.
  3. Define Encryptable Fields: Define an $encryptable property in your model with the list of attributes to encrypt.
use StriderWhite\Encryptable;

class YourModel extends Model
{
    use Encryptable;

    protected $encryptable = ['field1', 'field2'];
}
  1. 💾 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

GitHub 信息

  • Stars: 5
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2025-04-12