
PHPCMS 扩展开发主要通过模块化方式实现功能扩展。虽然 PHPCMS V9 已经停止官方更新,但其架构仍支持自定义模块和插件开发。要开发一个扩展或功能模块,需遵循系统约定的目录结构和编码规范。
1. 创建自定义模块
PHPCMS 模块通常放在 /phpcms/modules/ 目录下。新建一个模块目录,例如 mymodule,然后创建基本文件:
init.php:模块入口配置 classes/:存放类文件 functions/:辅助函数 language/:语言包 templates/:前台或后台模板 mymodule.php:控制器文件(继承于 pc_base)
在控制器中编写逻辑,例如:
class mymodule { public function __construct() { $this->db = pc_base::load_model(‘content_model’); } public function init() { $data = $this->db->select(); include template(‘mymodule’, ‘index’); }}
2. 添加后台菜单与权限
模块安装后需要在后台显示菜单项。编辑 /phpcms/languages/zh-cn/mymodule.lang.php 添加语言项:
立即学习“PHP免费学习笔记(深入)”;
<?php$LANG[‘mymodule’] = ‘我的模块’;$LANG[‘manage’] = ‘管理页面’;?>
进入后台“模块管理”,添加新模块,并设置对应的控制器和方法。也可手动插入数据库表 v9_module 记录。
3. 使用钩子(Hook)机制扩展功能
PHPCMS 支持通过“插件点”(即钩子)注入代码。在关键流程中调用 pc_base::load_app_class(‘hook’, ‘admin’) 或使用系统触发器。
例如,在内容发布前后执行操作:
找到对应位置如 content_add_after 钩子 编写插件类,注册该钩子 将插件放入 /caches/configs/hooks.php 注册
示例钩子注册:
‘content_add_after’ => array( ‘mymodule’ => array(‘class’ => ‘mymodule_hook’, ‘file’ => ‘modules/mymodule/classes/mymodule_hook.class.php’))
4. 数据库与模型集成
若扩展需要独立数据表,可在模块安装时执行 SQL 脚本。创建 install.sql 并在安装逻辑中调用:
$sql = file_get_contents(PC_PATH.’modules/mymodule/install.sql’);$this->db->sql_query($sql);
自定义模型可继承 model 类,存放在 modules/mymodule/model/ 中。
5. 前端访问与URL路由
确保 Apache/Nginx 配置支持 PATH_INFO 或伪静态。前端访问地址格式一般为:
index.php?m=mymodule&c=mymodule&a=init
可配合 urlrule 实现友好 URL。
基本上就这些。只要理解 PHPCMS 的 MVC 结构和加载机制,扩展开发并不复杂,关键是遵循原有框架风格,避免直接修改核心文件。

评论(0)