TP6.0 容器和依赖注入
2023-06-13 09:16:43 时间
1. 什么是依赖注入
依赖注入本质上是指类的依赖通过构造器完成自动注入。
例如:在控制器构造方法或普通方法中一旦对参数进行对象类型约束则会自动触发依赖注入,由于访问控制器的参数都来自于URL请求,普通变量就是通过参数绑定自动获取,对象变量则是通过依赖注入生成
依赖注入:即允许通过类的方法传递对象的能力,并且限制了对象的类型(约束),而传递对象的背后那个类被自动绑定并且实例化了,这就是依赖注入
2. 容器
依赖注入的类统一由容器管理的,大多数情况下是自动绑定和自动实例化的
如果想手动来完成绑定和实例化,可以使用 bind() 和 app() 助手函数实现
3. 使用示例
// 绑定类库标识,这个标识具有唯一性,以便快速调用
bind('one', \app\model\User::class);
// 快速调用并且自动实例化对象,类库标识严格区分大小写
app('one');
// 第二参数用于传参,
// 自动实例化对象的方式默认使用单例模式,第三参数为true时调用会重新实例化
app('one', [], true);
// 也可以直接绑定一个类到容器中并自动实例化
app(\app\model\User::class);
// 使用 bind([]) 可以批量绑定
// 不同系统有专门提供批量绑定的文件 app/provider.php
bind([
'user' => \app\model\User::class,
'admin' => \app\model\Admin::class,
]);
4. 容器 Provider 定义文件
框架文件 app/provider.php 用于定义容器类, 将类绑定到容器中
自己封装的一些类文件可以通过该文件将类绑定到容器中, 以便快速调用
<?php
use app\ExceptionHandle;
use app\Request;
// 容器Provider定义文件
return [
'think\Request' => Request::class,
'think\exception\Handle' => ExceptionHandle::class,
// 扩展类库
'math' => Math::class,
'layui' => Layui::class,
];
快速调用
app('layui')->table('用户列表', 10, $data);
相关文章
- 从一个ctf简单总结下mysql手工注入
- 怎么防止sql注入攻击_网络安全的威胁
- 如何向大模型注入知识?达摩院通义对话模型SPACE系列探索
- 【Android 逆向】Android 进程注入工具开发 ( 调试进程中寄存器的作用 | 通过 EIP 寄存器控制程序运行 | EIP 寄存器的存档与恢复 )
- 【Groovy】循环控制 ( Number 注入函数实现循环 | times 函数 | upto 函数 | downto 函数 | step 函数 | 闭包作为最后参数可写在外面 )
- sql注入数据库原理详情介绍
- SQL注入攻击对MSSQL的威胁及防护策略(sql注入 mssql)
- 利用MSSQL辅助进行数据库查询注入(mssql辅助注入)
- MSSQL注入攻击技术分析与防范(mssql注入 注释)
- MSSQL注入攻击怎么办?(mssql 注入执行命令)
- 攻击MSSQL注入:预防布尔型攻击的保护策略(mssql注入 布尔型)
- 注入mssql终结者:安全保护数据库免受命令注入攻击(mssql 止数据库命令)
- PHP中防止SQL注入攻击和XSS攻击的两个简单方法
- 防ASP注入终极防范
- 简单实用的PHP防注入类实例