PHPCMS 插件开发教程及经验谈

虽说 PHPCMS 开源,但其它开发文档及参考资料实在少得可怜。进行二次开发时,自己还得慢慢去研究它的代码,实在让人郁闷。

PHPCMS 的“Baibu/Google地图”实在有待改进,对于数据量比较大的网站来说,就一个字,烂!为了 SEO 不得不另辟蹊径,于是研究了几个 PHPCMS 自带的插件,为了方便以后的插件开发,顺便总结一下。

PHPCMS 插件基本目录结构:

  1. └plugin (插件目录名,下同)
  2. ├admin
  3. ├include
  4. ├templates
  5. ├admin.inc.php
  6. └priv.inc.php
  7. ├include
  8. ├common.inc.php
  9. └priv.inc.php
  10. ├install
  11. ├languages
  12. ├plugin.lang.php
  13. └plugin_admin.lang.php
  14. ├templates
  15. ├chmod.txt
  16. ├config.inc.php
  17. ├extention.inc.php
  18. └mysql.sql
  19. ├uninstall
  20. ├delete.txt
  21. ├extention.inc.php
  22. └mysql.sql
  23. └index.php

先讲讲插件的安装吧。文件夹:plugin/install

plugin/install/languages 文件夹内的文件是你所开发的插件的语言标签文件。语言标签类似这样子的“ $LANG['tag_name'] = '语言标签内容''; ”,语言标签文件通常有两个,一个是前台的,一个是后台的。

plugin/install/templates 文件夹内的插件模板文件在安装时会被复制到当前模板方案所在目录下的插件模板目录里(如 templates/default/plugin),所以如果安装插件后要更换模板方案,需要把插件模板目录复制一下。但是,如果你开发的插件没有前台功能,templates 这个文件夹可以直接删掉。顺便提下,name.inc.php 文件存放的是当前目录下的所有模板文件的中文名,每一个模板目录里都有这个文件的。

如果你所开发的插件需要将数据写入指定文件夹内时,需要将指定文件夹路径保存到 chmod.txt 文件内,插件在安装时会赋予所指定的文件夹写入权限。格式:“plugin/data/”,每行一条记录。

config.inc.php 文件保存的是插件的相关信息,如插件名称、开发者相关资料什么的。如下:

  1. $module = "sitemap";
  2. $modulename = "XML Sitemap";
  3. $introduce = "";
  4. $author = "Victor";
  5. $authorsite = "http://www.sougee.com/";
  6. $authoremail = "admin@sougee.com";

extention.inc.php 文件主要用于创建后台菜单,通常是模块管理下相关菜单及模板管理下相关菜单。后台菜单链接地址的格式说明如下:

  1. /*
  2. * mod=sitemap 模块名称,插件文件夹
  3. * file=build 对应plugin/admin/build.inc.php文件
  4. * action=manage 相关参数
  5. * 如果这里的mod=phpcms,file=build 对应的则是根目录下的admin/build.inc.php文件
  6. */
  7. ?mod=sitemap&file=type&action=manage
  8. /*
  9. * 以下的菜单链接通常用于模块的 "新建模板" 或 "模板管理"
  10. * 给相关插件添加菜单时,只要把 module 的值改为插件模块名即可($module)
  11. */
  12. ?mod=phpcms&file=template&action=add&module=guestbook
  13. /*
  14. * 如果你的插件涉及语言标签文件
  15. * 务必在extention.inc.php文件里加入以下代码
  16. * 作用是将插件里的语言标签文件复制到PHPCMS根目录下的languages/文件夹里
  17. */
  18. dir_copy(PHPCMS_ROOT . $installdir . '/install/languages/', PHPCMS_ROOT . 'languages/' . LANG . '/');

mysql.sql 文件里有一条语句是必须的,“INSERT INTO `phpcms_module` ...”,需不需要创建表什么的就看你开发的插件而定了。

插件的卸载。文件夹:plugin/uninstall

主要就是三个文件(请看插件基本目录结构)。作用分别是:删除插件文件,删除插件相关的表及数据(后台菜单)。

以上内容只是前菜,下面端上主菜了,以我自己开发的“XML Sitemap”插件为例,扭扭脖子开始吧。

先说说下面两个文件的代码,注意看注释
plugin/include/common.inc.php
plugin/include/priv.inc.php

  1. /*
  2. * plugin/include/common.inc.php
  3. */
  4. $mod = 'sitemap';  //模块名称,即插件目录名
  5. define('MOD_ROOT', substr(dirname(__FILE__), 0, -8));  //定义模块根目录
  6. require substr(MOD_ROOT, 0, -strlen($mod)).'include/common.inc.php';  //包含phpcms相关文件
  7. /*
  8. * plugin/include/priv.inc.php
  9. * 设置当前插件有哪些权限
  10. * 'file'=>'' 为空指的是plugin/admin下所有的文件
  11. * 'file'=>'build' build对应plugin/admin/build.inc.php文件
  12. * 'file'=>'setting' setting对应plugin/admin/setting.inc.php文件
  13. * 'action'=>'manage' 指定允许接收的地址栏参数,多个参数用逗号隔开
  14. */
  15. return array(
  16. 'all'=>array('name'=>'模块管理', 'file'=>'', 'action'=>''),
  17. 'build'=>array('name'=>'生成站点地图', 'file'=>'build', 'action'=>'manage'),
  18. 'setting'=>array('name'=>'模块配置', 'file'=>'setting', 'action'=>''),
  19. );

你要是仔细观察,会发现还有个 plugin/admin/priv.inc.php 文件没设置权限,由于这个文件比较特殊,所以无需设置权限,系统会自动进行相关处理。如果你开发的插件不需要设置权限,你只要把 plugin/include 及 plugin/admin 这两个文件夹下的 priv.inc.php 文件删除即可。

plugin/admin 文件夹里的是插件后台相关文件,可以说是插件的核心部分。其下文件的命名方式是:xxx.inc.php ,不过其中的 priv.inc.php 是插件“权限设置”页面,此文件名不能更改,若插件不考虑权限的话可直接删除,而 admin.inc.php 文件是必须有的,它是插件连接后台的桥梁。

plugin/admin/templates 下是插件后台模板文件,模板文件的命名方式是:xxx.tpl.php ,不过如果所开发的插件涉及到前台标签,还需要几个特殊的模板文件,如下:

  1. /*
  2. * 经研究,这几个插件标签模板文件貌似是固定的
  3. * 这里的 plugin 是指插件目录名
  4. */
  5. tag_plugin_add.tpl.php
  6. tag_plugin_ajax_edit.tpl.php
  7. tag_plugin_copy.tpl.php
  8. tag_plugin_edit.tpl.php
  9. tag_plugin_manage.tpl.php

讲到这里,PHPCMS插件开发也算是入门了,不过记住修行还在个人,其路依然漫漫。与君共勉!

上一篇:Compile groovy mixed with java in Maven


下一篇:[array] leetcode - 53. Maximum Subarray - Easy