
PSR-11 规范定义了 PHP 依赖注入容器的标准接口。这一标准化使得库能够从任何容器实现中检索服务,从而提升不同框架和库之间的互操作性。
理解依赖注入容器 (DIC)
依赖注入容器负责:
- 管理服务定义
- 创建服务实例
- 解析依赖项
- 管理对象生命周期
容器接口示例
立即学习“PHP免费学习笔记(深入)”;
基本实现
以下是一个符合 PSR-11 标准的简单依赖注入容器实现示例 (代码略,此处省略了实现细节,仅保留说明)。
高级用法
-
依赖注册服务: 可以注册依赖于其他服务的服务。例如,一个需要数据库连接的
UserService可以这样设置:
db = $db;
}
public function getUser() {
return "用户数据来自 " . $this->db->connect();
}
}
// 使用示例
$container = new SimpleContainer(); // 假设 SimpleContainer 是一个容器实现
$container->set('database', new DatabaseConnection());
$container->set('userservice', new UserService($container->get('database')));
$userService = $container->get('userservice');
echo $userService->getUser(); // 输出:用户数据来自 数据库已连接!
?>
- 使用工厂函数: 可以使用工厂函数注册服务,允许更复杂的实例化逻辑:
set('userservice', function (ContainerInterface $c) {
return new UserService($c->get('database'));
});
// 使用示例
$userService = $container->get('userservice');
echo $userService->getUser(); // 输出:用户数据来自 数据库已连接!
?>
实际应用示例
RPCMS是一款基于PHP+MYSQL的轻量型内容管理/博客系统,支持PHP5.6版本以上,支持win/Linux系统。它自主研发的RP框架(OPP方式),采用MVC架构搭建的高效、稳定的内容管理系统。灵活小巧,但有着强大的扩展性、丰富的插件接口和大量的模板。统一采用模板标签,轻松上手,让开发更方便!智能缓存机制让网站运行方面大幅度提高。系统特点:源码简洁、体积轻巧、功能丰富、安全、灵活等特点,完
- 服务注册:
set('api.key', 'secret-key-123');
// 工厂函数
$container->set('database', function (ContainerInterface $container) {
return new PDO(
$container->get('db.dsn'),
$container->get('db.user'),
$container->get('db.pass')
);
});
// 依赖服务
$container->set('userrepository', function (ContainerInterface $container) {
return new UserRepository($container->get('database'));
});
?>
- 服务检索:
users = $container->get('userrepository');
}
}
?>
框架集成示例 (Laravel)
(代码略,此处省略了 Laravel 集成代码示例,仅保留说明)
最佳实践
-
服务解析: 避免使用服务定位器模式,而应使用显式依赖注入。
-
容器配置: 使用配置驱动的服务定义,而不是运行时服务定义。
后续
下一篇文章将探讨 PSR-14 (事件调度程序接口)。
资源
- 官方 PSR-11 规范
- PHP-DI 文档










