## 安装[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%AE%89%E8%A3%85)
> composer require zzstudio/think-addons
## [](https://github.com/zz-studio/think-addons#%E9%85%8D%E7%BD%AE)配置[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E9%85%8D%E7%BD%AE)
### [](https://github.com/zz-studio/think-addons#%E7%94%9F%E6%88%90%E9%85%8D%E7%BD%AE)生成配置[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E7%94%9F%E6%88%90%E9%85%8D%E7%BD%AE)
系统安装后会自动在 config 目录中生成 addons.php 的配置文件, 如果系统未生成可在命令行执行
~~~html
php think addons:config
~~~
快速生成配置文件
### [](https://github.com/zz-studio/think-addons#%E5%85%AC%E5%85%B1%E9%85%8D%E7%BD%AE)公共配置[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%85%AC%E5%85%B1%E9%85%8D%E7%BD%AE)
```
'addons' => [
// 是否自动读取取插件钩子配置信息(默认是开启)
'autoload' => true,
// 当关闭自动获取配置时需要手动配置hooks信息
'hooks' => [ // 可以定义多个钩子
'testhook'\=>'test'
// 键为钩子名称,用于在业务中自定义钩子处理,值为实现该钩子的插件,
// 多个插件可以用数组也可以用逗号分割 ],
'route' => [],
'service' => [],
];
```
或者在\\config目录中新建`addons.php`,内容为:
```
<?php
return [
// 是否自动读取取插件钩子配置信息
'autoload' => false,
// 当关闭自动获取配置时需要手动配置hooks信息
'hooks' => [
// 可以定义多个钩子
'testhook'\=>'test' // 键为钩子名称,用于在业务中自定义钩子 处理,值为实现该钩子的插件,// 多个插件可以用数组也可以用逗号 分割
],
'route' => [],
'service' => [],
]
?>
```
## 创建插件[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BA%E6%8F%92%E4%BB%B6)
> 创建的插件可以在view视图中使用,也可以在php业务中使用
安装完成后访问系统时会在项目根目录生成名为`addons`的目录,在该目录中创建需要的插件。
下面写一个例子:
### [](https://github.com/zz-studio/think-addons#%E5%88%9B%E5%BB%BAtest%E6%8F%92%E4%BB%B6)创建test插件[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BAtest%E6%8F%92%E4%BB%B6)
> 在addons目录中创建test目录
### [](https://github.com/zz-studio/think-addons#%E5%88%9B%E5%BB%BA%E9%92%A9%E5%AD%90%E5%AE%9E%E7%8E%B0%E7%B1%BB)创建钩子实现类[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BA%E9%92%A9%E5%AD%90%E5%AE%9E%E7%8E%B0%E7%B1%BB)
> 在test目录中创建 Plugin.php 类文件。注意:类文件首字母需大写
```
<?php
namespace addons\\test; // 注意命名空间规范
use think\\Addons;
/\*\*
\* 插件测试
\* @author byron sampson
\*/
class Plugin extends Addons // 需继承think\\Addons类
{
// 该插件的基础信息
public $info \= \[
'name' \=> 'test', // 插件标识
'title' \=> '插件测试', // 插件名称
'description' \=> 'thinkph6插件测试', // 插件简介
'status' \=> 1, // 状态
'author' \=> 'yms',
'version' \=> '0.1'
\];
/\*\*
\* 插件安装方法
\* @return bool
\*/
public function install()
{
return true;
}
/\*\*
\* 插件卸载方法
\* @return bool
\*/
public function uninstall()
{
return true;
}
/\*\*
\* 实现的testhook钩子方法
\* @return mixed
\*/
public function testhook($param)
{
// 调用钩子时候的参数信息
//print\_r($param);
// 当前插件的配置信息,配置信息存在当前目录的config.php文件中,见下方
//print\_r($this->getConfig());
// 可以返回模板,模板文件默认读取的为插件目录中的文件。模板名不能为空!
return $this\->fetch('info');
}
}
```
### 创建插件配置文件[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BA%E6%8F%92%E4%BB%B6%E9%85%8D%E7%BD%AE%E6%96%87%E4%BB%B6)
> 在test目录中创建config.php类文件,插件配置文件可以省略。
```
<?php
return \[
'display' \=> \[
'title' \=> '是否显示:',
'type' \=> 'radio',
'options' \=> \[
'1' \=> '显示',
'0' \=> '不显示'
\],
'value' \=> '1'
\]
\];
```
### 创建钩子模板文件[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BA%E9%92%A9%E5%AD%90%E6%A8%A1%E6%9D%BF%E6%96%87%E4%BB%B6)
> 在test->view目录中创建info.html模板文件,钩子在使用fetch方法时对应的模板文件。
```
hello tpl 如果插件中需要有链接或提交数据的业务,可以在插件中创建controller业务文件, 要访问插件中的controller时使用addon\_url生成url链接。 如下: link test 或 link test 格式为: test为插件名,Action为controller中的类名\[多级控制器可以用.分割\],link为controller中的方法
```
### 创建插件的controller文件[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E5%88%9B%E5%BB%BA%E6%8F%92%E4%BB%B6%E7%9A%84controller%E6%96%87%E4%BB%B6)
> 在test目录中创建controller目录,在controller目录中创建Index.php文件 controller类的用法与tp6中的controller一致
```
<?php namespace addons\\test\\controller; class Index { public function link() { echo 'hello link'; } }
```
## 使用钩子[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#%E4%BD%BF%E7%94%A8%E9%92%A9%E5%AD%90)
> 创建好插件后就可以在正常业务中使用该插件中的钩子了 使用钩子的时候第二个参数可以省略
### [](https://github.com/zz-studio/think-addons#%E6%A8%A1%E6%9D%BF%E4%B8%AD%E4%BD%BF%E7%94%A8%E9%92%A9%E5%AD%90)模板中使用钩子
```
{:hook('testhook', \['id'\=>1\])}
```
### php业务中使用[#](https://www.cnblogs.com/zhangxilong/p/15958978.html#php%E4%B8%9A%E5%8A%A1%E4%B8%AD%E4%BD%BF%E7%94%A8)
> 只要是thinkphp6正常流程中的任意位置均可以使用
```
hook('testhook', \['id'=>1\])
```
### 插件公共方法
```
/\*\* \* 处理插件钩子 \* @param string $event 钩子名称 \* @param array|null $params 传入参数 \* @param bool $once 是否只返回一个结果 \* @return mixed \*/ function hook($event, $params = null, bool $once = false); /\*\* \* 读取插件的基础信息 \* @param string $name 插件名 \* @return array \*/ function get\_addons\_info($name); /\*\* \* 获取插件Plugin的单例 \* @param string $name 插件名 \* @return mixed|null \*/ function get\_addons\_instance($name); /\*\* \* 插件显示内容里生成访问插件的url \* @param $url 在插件控制器中可忽略插件名,在非插件中生成时需指定插件名。例:插件名://控制器/方法 \* @param array $param \* @param bool|string $suffix 生成的URL后缀 \* @param bool|string $domain 域名 \* @return bool|string \*/ function addons\_url($url = '', $param = \[\], $suffix = true, $domain = false);
```
- thinkphp6执行流程(一)
- php中use关键字用法详解
- Thinkphp6使用腾讯云发送短信步骤
- 路由配置
- Thinkphp6,static静态资源访问路径问题
- ThinkPHP6.0+ 使用Redis 原始用法
- smarty在thinkphp6.0中的最佳实践
- Thinkphp6.0 搜索器使用方法
- 从已有安装包(vendor)恢复 composer.json
- tp6with的用法,表间关联查询
- thinkphp6.x多对多如何添加中间表限制条件
- thinkphp6 安装JWT
- 缓存类型
- 请求信息和HTTP头信息
- 模型事件用法
- 助手函数汇总
- tp6集成Alipay 手机和电脑端支付的方法
- thinkphp6使用jwt
- 6.0session cookie cache
- tp6笔记
- TP6(thinkphp6)队列与延时队列
- thinkphp6 command(自定义指令)
- command(自定义指令)
- 本地文件上传
- 缓存
- 响应
- 公共函数配置
- 七牛云+文件上传
- thinkphp6:访问多个redis数据源(thinkphp6.0.5 / php 7.4.9)
- 富文本编辑器wangEditor3
- IP黑名单
- 增删改查 +文件上传
- workerman 定时器操作控制器的方法
- 上传文件到阿里云oss
- 短信或者邮箱验证码防刷代码
- thinkphp6:访问redis6(thinkphp 6.0.9/php 8.0.14)
- 实现关联多个id以逗号分开查询数据
- thinkphp6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 用mpdf生成pdf文件(php 8.1.1 / thinkphp v6.0.10LTS )
- 生成带logo的二维码(php 8.1.1 / thinkphp v6.0.10LTS )
- mysql数据库使用事务(php 8.1.1 / thinkphp v6.0.10LTS)
- 一,创建过滤IP的中间件
- 源码解析请求流程
- 验证码生成
- 权限管理
- 自定义异常类
- 事件监听event-listene
- 安装与使用think-addons
- 事件与多应用
- Workerman 基本使用
- 查询用户列表按拼音字母排序
- 扩展包合集
- 查询用户数据,但是可以通过输入用户昵称来搜索用户同时还要统计用户的文章和粉丝数
- 根据图片的minetype类型获取文件真实拓展名思路
- 到处excel
- 用imagemagick库生成缩略图
- 生成zip压缩包并下载
- API 多版本控制
- 用redis+lua做限流(php 8.1.1 / thinkphp v6.0.10LTS )
- 【thinkphp6源码分析三】 APP类之父, 容器Container类
- thinkphp6表单重复提交解决办法
- 小程序授权
- 最简单的thinkphp6导出Excel
- 根据访问设备不同访问不同模块
- 服务系统
- 前置/后置中间件
- 给接口api做签名验证(php 8.1.1 / thinkphp v6.0.10LTS )
- 6实现邮箱注册功能的细节和代码(点击链接激活方式)
- 使用前后端分离的验证码(thinkphp 6.0.9/php 8.0.14/vue 3.2.26)
- 前后端分离:用jwt+middleware做用户登录验证(php 8.1.1 / thinkphp v6.0.10LTS )
- vue前后端分离多图上传
- thinkphp 分组、页面跳转与ajax
- thinkphp6 常用方法文档
- 手册里没有的一些用法
- Swagger 3 API 注释
- PHP 秒级定时任务
- thinkphp6集成gatewayWorker(workerman)实现实时监听
- thinkphp6按月新增数据表
- 使用redis 实现消息队列
- api接口 统一结果返回处理类
- 使用swoole+thinkphp6.0+redis 结合开发的登录模块
- 给接口api做签名验证
- ThinkPHP6.0 + UniApp 实现小程序的 微信登录
- ThinkPHP6.0 + Vue + ElementUI + axios 的环境安装到实现 CURD 操作!
- 异常$e
- 参数请求验证自定义和异常错误自定义