定制 acelot/resolver 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

acelot/resolver

最新稳定版本:2.4.0

Composer 安装命令:

composer require acelot/resolver

包简介

Dependency auto resolver for PHP 7 and 8

README 文档

README

Build Status Code Climate

Resolver is a dependency auto resolver for PHP 7 and 8. Supports PSR-11 ContainerInterface.

Installation

composer require acelot/resolver

Why?

Imagine that you have a controller:

class UsersController
{
    public function __construct(UsersService $service)
    {
        // ...
    }
}

As you can see the controller requires UsersService in constructor. To resolve this dependency you can just pass the new instance of UsersService. Let's do this:

$service = new UsersService();
$controller = new UsersController($service);

It doesn't work, because UsersService, in turn, requires UsersRepository to access the data.

class UsersService
{
    public function __construct(UsersRepository $repository)
    {
        // ...
    }
}

Okay, let's create the repository instance!

$repository = new UsersRepository();
$service = new UsersService($repository);
$controller = new UsersController($service);

Sadly, it still doesn't work, because we encountering the new dependency! The repository, surprisingly, requires a database connection :)

class UsersRepository
{
    public function __construct(Database $db)
    {
        // ...
    }
}

You say "Eat this!".

$db = new Database('connection string here');
$repository = new UsersRepository($db);
$service = new UsersService($repository);
$controller = new UsersController($service);

Success! We have finally created the instance of UsersController! Now imagine that you have ten or hundred controllers like this?! With Resolver you can greatly simplify creation of classes. In what turns this code using Resolver:

$resolver = new Resolver([
    Database::class => ObjectDefinition::define(Database::class)->withArgument('connectionString', 'connection string here')
]);

$controller = $resolver->resolve(UsersController::class);

And it's all.

How it works?

Resolver resolves the classes by using Reflection. Through reflection the Resolver finds out all dependencies of the class and all dependencies of dependencies and so on. When Resolver reaches the deepest dependency it starts creating instances of these one by one until the top class. The resolved classes are stored in local array to avoid re-resolving.

Available definitions

  • FactoryDefinition (short alias factory())
  • ObjectDefinition (short alias object())
  • ValueDefinition (short alias value())

Instance sharing

Resolved definitions can be shared between calls via ->shared() method. This method available in FactoryDefinition and ObjectDefinition. ValueDefinition is shared always by design.

Resolver (c) by Valeriy Protopopov.

Resolver is licensed under a MIT license.

统计信息

  • 总下载量: 2.61k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 12
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 1

GitHub 信息

  • Stars: 12
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2017-02-28

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固