当前位置:文档之家› phpcms v9二次开发手册

phpcms v9二次开发手册


<?php ?>
pc_base::load_sys_class('db_factory', '', 0); class model { //数据库配置 protected $db_config = ''; //数据库连接 protected $db = ''; //调用数据库的配置项 protected $db_setting = 'default'; //数据表名 protected $table_name = ''; //表前缀 public $db_tablepre = ''; ……
= 'basic', $module = '', $catid = '', $color = '', $allowupload = 0, $allowbrowser = 1,$alowuploadexts = '',$height = 200,$disabled_page = 0) {
} //图片上传调用 public static function images($name, $id = '', $value = '', $moudle='', $catid='', $size = 50, $class = '', $ext = '', $alowexts = '',$thumb_setting = array(),$watermark_setting = 0 ) { } …… ?>
调用方法
如调用系统配置中的 web_path:
pc_base::load_config('system', web_path ');
CMS 入口文件:
PHPCMS 是采用 MVC 设计模式开发,基于模块和操作的方式进行访问,采用单一入 口模式进行项目部署和访问,无论访问任何一个模块或者功能,只有一个统一的 入口。
M 模型/模块名称 phpcms/modules 中模块目录名称 必须 C 控制器名称 phpcms/modules/模块/*.php 文件名称 必须 A 事件名称 phpcms/modules/模块/*.php 中方法名称 模块访问方法[示例]:
二次开发命名规范 类文件需要以.class.php 为后缀(这里是指的 phpcms 的系统类库文件和模块中 的类库文件,第三方引入的不做要求),例如 http.class.php。 函数文件需要以.func.php 为后缀(第三方引入的不做要求),例如 mail.func.php。 类名和文件名一致,例如 phpcmsapp 类的文件命名是 phpcmsapp.class.php。 数据模型需要以“数据表名称_model.class.php”为形式,类名称与文件名必须 相同。
pc_base::load_app_class(‘classname’,’admin’) 实例化模块类 pc_base::load_sys_func (‘funcfile’) 调用系统函数库
全局函数文件:
文件路径:根目录/phpcms/libs/functions/global.func.php 代码片段如下:
通过实例化该类可以,调用在程序中调用编辑器、表单上传、日期选择、栏目结 构等表单。 实例化方法:pc_base::load_sys_class('form', '', 0);
模板解析缓存类:
文件路径:根目录/phpcms/libs/classes/template_cache.class.php 。 代码 片段如下:
<?php
final class template_cache {
public function template_compile($module, $template, $style =
‘default’)
{
$tplfile = $_tpl = PC_PATH.'templates'.DIRECTORY_SEPARATOR.$style.DIRECTORY_SEPARATOR.$m odule.DIRECTORY_SEPARATOR.$template.'.html';
入口程序是在前期处理用户请求的引导程序。它是唯一一个可以被最终用户可以 直接请求运行的。
文件路径:根目录/index.php
<?php ?>
define('PHPCMS_PATH', dirname(__FILE__).DIRECTORY_SEPARATOR); include PHPCMS_PATH.'/phpcms/base.php'; pc_base::creat_app();
二次开发开发流程
创建数据库模型类
数据库模型位于:phpcms/model/目录下。
数据模型文件的命名规则建议为数据表名称+'_model.class.php'
如果在我们的创建的模块中我要使用一个数据库“test”,首先需要建立一个数 据库模型文件,文件名称为'test_model.class.php'
}
这样当您通过 url 访问 index 控制器的时候,系统会默认指向 MY_index.php 并且原文件的方法将被继承,可以直接使用。
系统配置文件
文件路径:根目录/caches/configs
database.php 数据库配置文件 system.php 系统配置文件 route.php 路由配置文件
<?php defined('IN_PHPCMS') or exit('No permission resources.'); pc_base::load_sys_class('model', '', 0); class test_model extends model { public function __construct() { $this->db_config = pc_base::load_config('database'); $this->db_setting = ‘default'; $this->table_name = 'test'; parent::__cons该类中方法进行数据库操作。
表单调用类:
文件路径:根目录/phpcms/libs/classes/form.class.php。 代码片段如下:
<?php class form { //编辑器调用 public static function editor($textareaid = 'content', $toolbar
?>
该文件中的函数,为全系统基础函数,可以在系统中直接调用。
二次开发技巧:
如果需要增加自己的全局函数,可根据需要增加到 /phpcms/libs/functions/global.func.php/extention.func.php 中,不会影响 升级
数据模型基类:
文件路径:根目录/phpcms/libs/classes/model.class.php 代码片段如下:
PC_PATH.'..'.DIRECTORY_SEPARATOR); define('CACHE_PATH', PHPCMS_PATH.'caches'.DIRECTORY_SEPARATOR);
…… ?>
该文件为框架入口文件,包含实例化系统/模块类方法,调用系统/模块方法,系 统常用常量等。如:
pc_base::load_model(‘*_model’) 加载数据库模型 pc_base::load_sys_class(‘classname’) 实例化系统类
…… ?> 该类作用为解析模板,解析模板及更新模板缓存
PHPCMS V9 二次开发
PHPCMS URL 访问: PHPCMS 是采用 MVC 设计模式开发,基于模块和操作的方式进行访问,采用单一入 口模式进行项目部署和访问,无论访问任何一个模块或者功能,只有一个统一的 入口。 参数名称 描述 位置 备注
这段代码首先加载了 phpcms 框架的引导文件 base.php,然后它根据指定的配 置文件建立了一个 Web 应用实例并运行。
PHPCMS 框架入口文件:
文件路径:根目录/phpcms/base.php 代码片段如下:
<?php define('IN_PHPCMS', true); define('PC_PATH', dirname(__FILE__).DIRECTORY_SEPARATOR); if(!defined('PHPCMS_PATH')) define('PHPCMS_PATH',
} ?>
数据库模型类名称必须与文件名称相同;
$this->db_setting = 'default'为数据库配置文件中配置数据库链接 池名称,默认为 default,一般情况下不需要修改。
$this->table_name = ‘test’为数据表名称
创建模块
如果要创建一个模块,只要在 phpcms/modules 目录下创建文件夹并放入你的控 制器类就可以了。
例如要开发一个叫做 test 的模块,那么首先在 phpcms/modules 目录下创建文 件夹,并将其命名为 test。模块的标准结构通常是这样的。
相关主题