定制 fatjon-lleshi/antares-container 二次开发

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

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

fatjon-lleshi/antares-container

最新稳定版本:v0.1.4

Composer 安装命令:

composer require fatjon-lleshi/antares-container

包简介

Lightweight autowiring PSR-11 container for PHP 8.2+

README 文档

README

Lightweight autowiring DI container for PHP 8.2+. Zero dependencies. Can be used standalone or as part of the Antares framework.

Installation

composer require fatjon-lleshi/antares-container

Standalone Usage

Autowiring

The container resolves classes and their dependencies automatically via reflection. No configuration needed for concrete classes.

use Antares\Container\Container;

class Logger {}

class UserService {
    public function __construct(
        private readonly Logger $logger
    ) {}
}

$container = new Container();
$service = $container->make(UserService::class);

Binding Interfaces

Bind an interface to a concrete implementation:

interface LoggerInterface {}
class FileLogger implements LoggerInterface {}

$container = new Container();
$container->bind(LoggerInterface::class, FileLogger::class);

$logger = $container->make(LoggerInterface::class);

Singletons

Register a class as a singleton — the same instance is returned on every make() call. Use this for classes that require primitive constructor arguments (like config values from .env):

$container->singleton(Database::class, function(Container $container) {
    return new Database(
        host: $_ENV['DB_HOST'],
        port: (int) $_ENV['DB_PORT'],
        name: $_ENV['DB_NAME'],
    );
});

$db = $container->make(Database::class);

Nested Autowiring

The container recursively resolves nested dependencies:

class Cache {}

class Repository {
    public function __construct(
        private readonly Database $db,
        private readonly Cache $cache,
    ) {}
}

$repository = $container->make(Repository::class);

Error Handling

Unbound Interface

If you try to resolve an interface without binding it, a ContainerException is thrown:

use Antares\Container\ContainerException;

try {
    $container->make(LoggerInterface::class);
} catch (ContainerException $e) {
    echo $e->getMessage();
}

Circular Dependency

Circular dependencies are detected and throw a ContainerException:

class A {
    public function __construct(public B $b) {}
}
class B {
    public function __construct(public A $a) {}
}

$container->make(A::class); // throws ContainerException: Circular dependency detected

Unresolvable Primitive

If a class constructor has primitive type hints (string, int, etc.) with no default values, the container cannot autowire them. Register the class as a singleton instead:

class Mailer {
    public function __construct(
        public readonly string $host,
        public readonly int $port,
    ) {}
}

$container->singleton(Mailer::class, fn() => new Mailer(
    host: $_ENV['MAIL_HOST'],
    port: (int) $_ENV['MAIL_PORT'],
));

Requirements

  • PHP 8.2+

License

MIT

统计信息

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

GitHub 信息

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

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-04-24

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固