rodrigonull/doctrine-encrypt
Composer 安装命令:
composer require rodrigonull/doctrine-encrypt
包简介
Package encrypts and decrypts Doctrine fields through life cycle events.
README 文档
README
Package encrypts and decrypts Doctrine fields through life cycle events. This version of the Doctrine Encrypt package distinguishes itself with the following features:
- Superior Annotation parsing & caching using Doctrine's built in libraries for superior performance
- Totally transparent field encryption: the value will only be encrypted in the database, never in the value
- Unit testing
Installation
Add rodrigonull/doctrine-encrypt to your Composer manifest.
{ "require": { "rodrigonull/doctrine-encrypt": "dev-master" } }
Configuration
Manually
Add the event subscriber to your entity manager's event manager. Assuming $em is your configured entity manager:
<?php //You should pick your own hexadecimal secret $secret = pack("H*", "dda8e5b978e05346f08b312a8c2eac03670bb5661097f8bc13212c31be66384c"); $subscriber = new DoctrineEncryptSubscriber( new \Doctrine\Common\Annotations\AnnotationReader, new \DoctrineEncrypt\Encryptors\AES256Encryptor($secret) ); $eventManager = $em->getEventManager(); $eventManager->addEventSubscriber($subscriber);
Usage
<?php namespace Your\Namespace; use Doctrine\ORM\Mapping as ORM; use DoctrineEncrypt\Configuration\Encrypted; /** * @ORM\Entity */ class Entity { /** * @ORM\Id * @ORM\GeneratedValue(strategy="AUTO") * @ORM\Column(type="integer") * @var int */ protected $id; /** * @ORM\Column(type="text") * @Encrypted * @var string */ protected $secret_data; }
License
This bundle is under the MIT license. See the complete license in the bundle
Versions
I'm using Semantic Versioning like described here.
统计信息
- 总下载量: 90
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 4
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2016-11-30