anexia/laravel-encryption
Composer 安装命令:
composer require anexia/laravel-encryption
包简介
Encryption and decryption for eloquent models
README 文档
README
A Laravel package that adds database encryption support to eloquent models.
1. Installation and configuration
1. Install via composer
Install the module via composer, therefore adapt the require part of your composer.json:
"require": {
"anexia/laravel-encryption": "1.0.0"
}
Now run
composer update [-o]
to add the packages source code to your /vendor directory and update the autoloading.
2. Add service provider to app config
'providers' => [
/*
* Package Service Providers...
*/
\Anexia\LaravelEncryption\DatabaseEncryptionServiceProvider::class,
]
3. Add cipher to database config
Currently only Postgres and PGP is supported.
'pgsql' => [
'driver' => 'pgsql',
'host' => env('DB_HOST', '127.0.0.1'),
'port' => env('DB_PORT', '5432'),
'database' => env('DB_DATABASE', 'forge'),
'username' => env('DB_USERNAME', 'forge'),
'password' => env('DB_PASSWORD', ''),
'charset' => 'utf8',
'prefix' => '',
'schema' => 'public',
'sslmode' => 'prefer',
'cipher' => 'pgp'
],
2. Usage
2.1 Models
Add the DatabaseEncryption Trait to your eloquent model.
<?php
namespace App;
use Anexia\LaravelEncryption\DatabaseEncryption;
use Illuminate\Notifications\Notifiable;
use Illuminate\Foundation\Auth\User as Authenticatable;
class User extends Authenticatable
{
use Notifiable, DatabaseEncryption;
/**
* The attributes that are mass assignable.
*
* @var array
*/
protected $fillable = [
'name', 'email', 'password',
];
/**
* The attributes that should be hidden for arrays.
*
* @var array
*/
protected $hidden = [
'password', 'remember_token',
];
/**
* @return array
*/
protected static function getEncryptedFields()
{
return [
'password'
];
}
/**
* @return string
*/
protected function getEncryptKey()
{
return 'thisismysupersecretencryptionkey';
}
}
2.2 Updates
Just call the save() method on the model. Fields will be encrypted automatically.
2.3 Queries
Per default the encrypted properties will be replaced by their corresponding "_encrypted" value.
$user = User::find(1);
The above query will have the property "password_encrypted" and no "password" property.
2.3.1 Decrypted properties
Use the macro withDecryptKey for automatic decryption.
2.3.1 'select *' queries
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1);
In the example above $user will have two properties:
- password: the decrypted password
- password_encrypted: the encrypted value from the database
- id
- name
- remember_token
2.3.2 Select certain fields
$user = User::->find(1, ['id']);
or
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1, ['id']);
In both examples above $user will only have one property:
- id
$user = User::->find(1, ['id', 'password']);
In the example above $user will only have two properties:
- id
- password_encrypted: the encrypted value from the database
$user = User::withDecryptKey('thisismysupersecretencryptionkey')->find(1, ['id', 'password']);
In the example above $user will only have three properties:
- id
- password: the decrypted password
- password_encrypted: the encrypted value from the database
2.3.3 Check for certain decoded values
Use the macro whereDecripted to run a "where field = value" query on an encrypted property.
$user = User::whereDecrypted('password', 'thisIsTheWantedPassword', 'thisismysupersecretencryptionkey')->first();
In the example above $user will be the first entry with the (decrypted) password 'thisIsTheWantedPassword'.
统计信息
- 总下载量: 4.07k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 2
- 点击次数: 1
- 依赖项目数: 1
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2018-10-10