在FastAdmin中可收自由扩展和开发插件,这里简单整理一个插件文档。在此以官方博客插件 为示例来介绍,因为官方博客插件是前后台都有的一套完整方案。

目录结构

  1. blog
  2. ├── application
  3. └── admin
  4. ├── controller
  5. └── blog
  6. ├── Category.php
  7. ├── Comment.php
  8. └── Post.php
  9. ├── lang
  10. └── zh-cn
  11. └── blog
  12. ├── model
  13. ├── BlogCategory.php
  14. ├── BlogComment.php
  15. └── BlogPost.php
  16. └── view
  17. └── blog
  18. ├── category
  19. ├── add.html
  20. ├── edit.html
  21. └── index.html
  22. ├── comment
  23. ├── add.html
  24. ├── edit.html
  25. └── index.html
  26. └── post
  27. ├── add.html
  28. ├── edit.html
  29. └── index.html
  30. ├── assets
  31. ├── css
  32. ├── main.css
  33. └── main.css.map
  34. ├── fonts
  35. ├── img
  36. ├── js
  37. ├── less
  38. └── lib
  39. ├── jquery.js
  40. └── jquery.pjax.js
  41. ├── controller
  42. ├── Ajax.php
  43. └── Index.php
  44. ├── lang
  45. └── zh-cn.php
  46. ├── model
  47. ├── Category.php
  48. ├── Comment.php
  49. └── Post.php
  50. ├── public
  51. └── assets
  52. └── js
  53. └── backend
  54. └── blog
  55. ├── category.js
  56. ├── comment.js
  57. └── post.js
  58. ├── view
  59. ├── common
  60. ├── commentlist.html
  61. ├── postlist.html
  62. └── sidebar.html
  63. └── index
  64. ├── archieve.html
  65. ├── category.html
  66. ├── index.html
  67. └── post.html
  68. ├── Blog.php
  69. ├── bootstrap.js
  70. ├── LICENSE
  71. ├── config.php
  72. ├── info.ini
  73. └── install.sql

目录介绍

  1. blog
  2. ├── application //此文件夹中所有文件会覆盖到根目录的/application文件夹
  3. ├── assets //此文件夹中所有文件会复制到/public/assets/addons/blog文件夹
  4. ├── controller //此文件夹为插件控制器目录
  5. ├── lang //此文件夹为插件语言包目录
  6. ├── model //此文件夹为插件模型目录
  7. ├── public //此文件夹中所有文件会覆盖到根目录的/public文件夹
  8. ├── view //此文件夹为插件视图目录
  9. ├── Blog.php //此文件为插件核心安装卸载控制器,必需存在
  10. ├── bootstrap.js //此文件为插件JS启动文件
  11. ├── LICENSE //版权文件
  12. ├── config.php //插件配置文件,我们在后台插件管理中点配置按钮时配置的文件,必需存在
  13. ├── info.ini //插件信息文件,用于保存插件基本信息,插件开启状态等,必需存在
  14. └── install.sql //插件数据库安装文件,此文件仅在插件安装时会进行导入

其中的applicationpublic文件夹会覆盖到根目录,这两个文件夹主要用于我们后台管理功能的开发,我们可以先在后台开发好对应的管理功能后,再将对应的功能打包进插件即可,FastAdmin在插件安装和卸载时会自动进行文件冲突检测,如果遇到冲突的文件会提醒用户是否进行覆盖或删除。

assets这个文件夹很关键,FastAdmin会将assets中的所有文件夹和文件复制到/public/assets/addons/blog/文件夹中去,这个blog即是我们的插件目录名称,assets文件夹中的所有文件不会进行文件冲突检测,/public/assets/addons/blog/这个目录下的文件,我们在视图文件中可以直接通过__ADDON__指向这个路径。因此在开发视图时我们可以先使用相对路径设计,完成后我们再统一加上这个__ADDON__的前缀

controllerlangmodelview这四个文件夹是我们插件前台功能的MVC部分,这部分文件夹不会复制或移动到其它位置。

Blog.php这个文件是插件的核心文件,我们可以在这个文件中编写插件安装或卸载时执行的脚本,或者在此插件中编写菜单的生成或删除,同时插件的行为方法也是编写在此文件中的,插件所支持的行为事件会在后面讲到。此文件命令规则为插件目录名称首字母大写。

bootstrap.js这个文件是插件的启动文件,插件在安装完启用后,FastAdmin会将此文件中的内容合并到/public/assets/js/addons.js中去,你可以在此编写插件核心JS或注册事件,在此JS中可以使用require依赖其它模块。同时在此插件中可以使用Fast、Backend、Lang等全局对象,因为在此之前此类对象已经加载且注册。

config.php这个文件是插件的配置文件,我们在后台插件管理中点配置按钮时会保存在此文件,此文件的内容格式为:

  1. <?php
  2. return [
  3. [
  4. //配置名称,该值在当前数组配置中确保唯一
  5. 'name' => 'yourname',
  6. //配置标题
  7. 'title' => '配置标题',
  8. //配置类型,支持string/text/number/datetime/array/select/selects/image/images/file/files/checkbox/radio/bool
  9. 'type' => 'string',
  10. //配置select/selects/checkbox/radio/bool时显示的列表项
  11. 'content' => [
  12. '1' => '显示',
  13. '0' => '不显示'
  14. ],
  15. //配置值
  16. 'value' => '1',
  17. //配置验证规则,更之规则可参考nice-validator文件
  18. 'rule' => 'required',
  19. 'msg' => '验证失败提示文字',
  20. 'tip' => '字段填写帮助',
  21. 'ok' => '验证成功提示文字'
  22. ],
  23. [
  24. 'name' => 'yourname2',
  25. 'title' => '配置标题2',
  26. 'type' => 'radio',
  27. 'options' => [
  28. '1' => '显示',
  29. '0' => '不显示'
  30. ],
  31. 'value' => '1',
  32. 'rule' => 'required',
  33. 'msg' => '验证失败提示文字',
  34. 'tip' => '字段填写帮助',
  35. 'ok' => '验证成功提示文字'
  36. ]
  37. ];

config.php中的值在FastAdmin任何地方均可使用get_addon_config('blog')来获取配置值

info.ini这个文件仅用于保存插件基础信息和开启状态,此文件的内容格式为

  1. name = blog
  2. title = 博客插件
  3. intro = 响应式博客插件,包含日志、评论、分类、归档等
  4. author = Karson
  5. website = https://www.fastadmin.net
  6. version = 1.0.0
  7. state = 1

install.sql 这个文件中只能是SQL语句,同时在此文件中可以使用__PREFIX__表示数据库表前缀,FastAdmin在安装导入SQL时自动进行替换。此文件的内容格式为

  1. ;我们在创建数据库时最好加上IF NOT EXISTS
  2. CREATE TABLE IF NOT EXISTS `__PREFIX__blog_category` (
  3. `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  4. `pid` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '父分类ID',
  5. `name` varchar(30) NOT NULL DEFAULT '' COMMENT '分类名称',
  6. `nickname` varchar(50) NOT NULL DEFAULT '' COMMENT '分类昵称',
  7. `flag` set('hot','index','recommend') NOT NULL DEFAULT '' COMMENT '分类标志',
  8. `image` varchar(100) NOT NULL DEFAULT '' COMMENT '图片',
  9. `keywords` varchar(255) NOT NULL DEFAULT '' COMMENT '关键字',
  10. `description` varchar(255) NOT NULL DEFAULT '' COMMENT '描述',
  11. `diyname` varchar(30) NOT NULL DEFAULT '' COMMENT '自定义名称',
  12. `createtime` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '创建时间',
  13. `updatetime` int(10) unsigned NOT NULL DEFAULT '0' COMMENT '更新时间',
  14. `weigh` int(10) NOT NULL DEFAULT '0' COMMENT '权重',
  15. `status` varchar(30) NOT NULL DEFAULT '' COMMENT '状态',
  16. PRIMARY KEY (`id`),
  17. KEY `weigh` (`weigh`,`id`),
  18. KEY `pid` (`pid`)
  19. ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 ROW_FORMAT=DYNAMIC COMMENT='博客分类表';
  20. ; 在执行插入时最好加上BEGIN;和COMMIT;
  21. BEGIN;
  22. INSERT INTO `__PREFIX__blog_category` VALUES ('1', '0', '默认分类', 'default', '', '/assets/img/qrcode.png', '', '', '', '1502112587', '1502112587', '0', 'normal');
  23. COMMIT;

行为事件

FastAdmin中的行为支持ThinkPHP5的所有行为,同时FastAdmin自定义部分专属的行为事件,以下是所有所支持的行为事件

标签位 描述 类型说明
app_init 应用初始化标签位 系统
app_begin 应用开始标签位 系统
module_init 模块初始化标签位 系统
action_begin 控制器开始标签位 系统
view_filter 视图输出过滤标签位 系统
app_end 应用结束标签位 系统
log_write 日志write方法标签位 系统
log_write_done 日志写入完成标签位 系统
response_end 输出结束标签位 系统
response_send 响应发送标签位 系统
upload_after 上传成功标签位 FastAdmin
login_init 登录标签位 FastAdmin
wipecache_after 清除缓存后标签位 FastAdmin
admin_nologin 管理员未登录标签位 FastAdmin
admin_nopermission 管理员无权限标签位 FastAdmin
upload_config_init 上传配置标签位 FastAdmin
config_init 系统配置标签位 FastAdmin

使用行为时在Blog.php中添加上对应的方法,FastAdmin在安装时、禁用、启用即可自动注册行为。但一定请注意在Blog.php中编写行为方法是使用的是驼峰式规则,例如upload_after,方法名则为uploadAfter,如果方法名使用upload_after则不会注册成功

至此,FastAdmin插件开发所涉及到的文件和文件夹已经介绍完了,如果有疑问,请及时在群或论坛反馈。

插件示例

我们准备了一篇插件开发简明教程,请点击这里查看

插件管理

FastAdmin插件分为在线安装和命令行安装,在线安装可以直接在后台插件管理进行安装和卸载。

命令行安装适合禁用或移除了后台插件管理功能的开发者使用,具体请参考命令行章节:一键管理插件

插件市场

目前FastAdmin官方已经上线插件市场,开发者可以在插件市场下载插件进行离线安装,地址:https://www.fastadmin.net/store.html

如果你开发了一款插件需要上架到FastAdmin的插件市场,可以通过在线发布插件的形式分享或售卖你的插件,请点击https://www.fastadmin.net/postaddon.html 查看