PHPCMS 使用图示和PHPCMS二次开发教程(转)

PHPCMS V9 核心文件说明

模块与控制器

模块:

phpcms v9框架中的模块,位于phpcms/modules目录中 每一个目录称之为一个模块。即url访问中的m。

访问content模块示例:http://www.yourname.com/index.php?m=content

控制器:

phpcms v9的控制器就是模块的类文件,位于phpcms/modules/模块/目录下面。类名成就是文件名+.php,例如一个名为abc的控制器,那么他的命名为abc.php即可。控制器类默认继承系统的函数库,可以直接使用。控制器类的类名称与控制器文件名必须相同。如果您创建了一个abc.php在test模块下,那么我们在浏览器里面输入URL:http://www.yourname.com/index.php?m=test&c=abc

二次开发技巧

如果要对已存在的控制器进行二次开发,为了方便升级不建议直接对内核文件直接修改该,您可以通过“MY_*.php”的形式进行二次开发。

例如您要对改phpcms/mood/index.php进行二次开发。您可以在与index.php同级的目录下建立"MY_index.php"

<?php class MY_index extends index{ function __construct() {parent::__construct(); } ……your code }

这样当您通过url访问index控制器的时候,系统会默认指向MY_index.php 并且原文件的方法将被继承,可以直接使用。

系统配置文件

文件路径:根目录/caches/configs

  • database.php 数据库配置文件
  • system.php 系统配置文件
  • route.php 路由配置文件

调用方法

如调用系统配置中的web_path:

pc_base::load_config(‘system‘, web_path ‘);

CMS入口文件:

PHPCMS是采用MVC设计模式开发,基于模块和操作的方式进行访问,采用单一入口模式进行项目部署和访问,无论访问任何一个模块或者功能,只有一个统一的入口。

入口程序是在前期处理用户请求的引导程序。它是唯一一个可以被最终用户可以直接请求运行的。

文件路径:根目录/index.php

<?php define(‘PHPCMS_PATH‘, dirname(__FILE__).DIRECTORY_SEPARATOR); include PHPCMS_PATH.‘/phpcms/base.php‘; pc_base::creat_app(); ?>

这段代码首先加载了 phpcms 框架的引导文件 base.php,然后它根据指定的配置文件建立了一个 Web 应用实例并运行。

Phpcms v9后台内容管理

Phpcms v9后台文章发布

PHPCMS V9 结构设计

根目录

|–api  结构文件目录

|–caches 缓存文件目录

   |– configs 系统配置文件目录

   |– caches_* 系统缓存目录

|–phpcms  phpcms框架主目录

   |– languages 框架语言包目录

   |– libs 框架主类库、主函数库目录

   |– model 框架数据库模型目录

   |– modules 框架模块目录

   |– templates 框架系统模板目录

|–phpsso_server  phpsso主目录

|–statics  系统附件包

   | – css 系统css包

   | – images 系统图片包

   | – js 系统js包

|–index.php  程序主入口

PHPCMS框架入口文件:

文件路径:根目录/phpcms/base.php 代码片段如下:

<?php define(‘IN_PHPCMS‘, true); define(‘PC_PATH‘, dirname(__FILE__).DIRECTORY_SEPARATOR); if(!defined(‘PHPCMS_PATH‘)) define(‘PHPCMS_PATH‘, PC_PATH.‘..‘.DIRECTORY_SEPARATOR); define(‘CACHE_PATH‘, PHPCMS_PATH.‘caches‘.DIRECTORY_SEPARATOR); …… ?>

该文件为框架入口文件,包含实例化系统/模块类方法,调用系统/模块方法,系统常用常量等。如:

pc_base::load_model(‘*_model’) 加载数据库模型 pc_base::load_sys_class(‘classname’) 实例化系统类 pc_base::load_app_class(‘classname’,’admin’) 实例化模块类 pc_base::load_sys_func (‘funcfile’) 调用系统函数库

全局函数文件:

文件路径:根目录/phpcms/libs/functions/global.func.php 代码片段如下:

<?php function new_addslashes($string){ if(!is_array($string)) returnaddslashes($string); foreach($string as $key => $val) $string[$key] = new_addslashes($val); return $string; } …… ?>

该文件中的函数,为全系统基础函数,可以在系统中直接调用。

二次开发技巧:

如果需要增加自己的全局函数,可根据需要增加到/phpcms/libs/functions/global.func.php/extention.func.php中,不会影响升级

数据模型基类:

文件路径:根目录/phpcms/libs/classes/model.class.php 代码片段如下:

<?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 = ‘‘; …… ?>

加载数据模型后,可以的数据库该类中方法进行数据库操作。

表单调用类:

文件路径:根目录/phpcms/libs/classes/form.class.php。 代码片段如下:

<?php class form { //编辑器调用 public static function editor($textareaid = ‘content‘, $toolbar = ‘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 ) { } …… ?>

通过实例化该类可以,调用在程序中调用编辑器、表单上传、日期选择、栏目结构等表单。 实例化方法: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.$module.DIRECTORY_SEPARATOR.$template.‘.html‘; …… ?>

该类作用为解析模板,解析模板及更新模板缓存

创建模块控制器类

为test模块增加一个名为myest的控制器 文件路径:根目录/phpcms/modules/test/mytest.php。 代码片段如下:

<?php  defined(‘IN_PHPCMS‘) or exit(‘No permission resources.‘);  classmytest {  function __construct() {  }  public function init() {  $var = ‘hello world!‘;  echo $myvar;      }  public function mylist() {  $var = ‘hello world!this is a example!‘;  echo $myvar;  }  } ?>

常用操作列表(1)

1.调用数据库模型

$this->db = pc_base::load_model(‘test_model‘);

其中$this->db中所支持的方法请参照phpcms/libs/classes/model.class.php中方法

2.加载系统类

$http = pc_base::load_sys_class(‘http‘); //实例化http类 pc_base::load_sys_class(‘format‘, ‘‘, 0); //调用form类,不进行实例化操作3.加载系统函

3.加载系统函数库

pc_base::load_sys_func(‘mail‘); //调用mail函数包

4. 加载模块类

$test = pc_base::load_sys_class(‘classname‘,’test’); //实例化test模块下 classname类

5.加载模块函数库

pc_base::load_sys_func(‘global‘,’test’); //调用test模块的global函数包

常用操作列表(2)

6.加载前台模板

include template(‘test‘, ‘mytest‘, ‘default‘);

7.加载后台模板

include $this->admin_tpl(‘mytest_admin_list‘);

8.权限控制

后台控制控制器需要加载admin模块下的admin类,并继承该类

<?php defined(‘IN_PHPCMS‘) or exit(‘No permission resources.‘); pc_base::load_app_class(‘admin‘,‘admin‘,0); class mytest_admin extends admin { //这个控制器需要登录后台才可以访问 } ?>

PHPCMS V9 模板与标签

  • PC标签
  • 评论模块
  • 会员模块
  • 友情链接模块
  • 投票模块
  • 公告模块
  • 专题模块
  • 内容模块
  • 工具箱
  • json工具箱
  • xml工具箱
  • get标签
  • 碎片工具箱
时间: 2024-08-01 22:42:49

PHPCMS 使用图示和PHPCMS二次开发教程(转)的相关文章

PHPCMS二次开发教程(转)

转自:http://www.cnblogs.com/semcoding/p/3347600.html PHPCMS V9 结构设计 根目录 |–api  结构文件目录 |–caches 缓存文件目录    |– configs 系统配置文件目录    |– caches_* 系统缓存目录 |–phpcms  phpcms框架主目录    |– languages 框架语言包目录    |– libs 框架主类库.主函数库目录    |– model 框架数据库模型目录    |– modules

Ecshop系统二次开发教程及流程演示

来源:互联网 作者:佚名 时间:03-01 16:05:31 [大 中 小] Ecshop想必大家不会觉得陌生吧,大部分的B2C独立网店系统都用的是Ecshop系统,很受用户的喜爱,但是由于Ecshop模板自带有很多Ecshop的Logo和版权信息,和一些其他需要修改的地方,所以我们需要对Ecshop系统做二次开发,下面就来看看具体操作步骤吧 一.Ecshop简介: ECShop是Comsenz公司推出的一款B2C独立网店系统,适合企业及个人快速构建个性化网上商店.系统是基于PHP语言及MYSQ

WeCenter二次开发教程(一):熟悉模板结构

<1>程序文件目录介绍: app – 应用目录 models – 模型目录 plugins – 插件目录 static – 静态文件 system – 系统目录 views – 模板目录 我们简单的页面二次开发主要还是关注static和views这两个文件. 下面在介绍一下这个文件里面对应的目录功能 static里面文件分别是: admin: 后台控制面板的css,js,图片这些文件: common: 网站公用的图片,比如社区默认的头像图片: css:主要介绍css/default里的css文

最好最实用的PHP二次开发教程

◆二次开发 1.什么是二次开发? 二次开发,简单的说就是在现有的软件上进行定制修改,功能的扩展,然后达到自己想要的功能和效果,一般来说都不会改变原有系统的内核. 2.为什么要二次开发? 随着信息化技术的不断发展,IT行业涌现出了一系列优秀的开源作品,其作者或是个人,或是项目小组,或是软件公司.选择和 应用这些优秀的开源软件,并在此基础上进行符合业务需求的二次开发,将给企业节省信息化成本(时间成本及开发成本)的同时,更能带来技术上的保障.这就是 我们常听的:站在巨人的肩膀上,你将看的更远.所以国内

Odoo 二次开发教程【一】 Odoo 的安装

一,安装的两种方式: 1) deb包安装: 此安装方式适用于简单不需要太多的人工干预,大多数插件都在deb中涵盖了.具体的步骤如下: 1.编辑 /etc/apt/source.list 文件,在末尾添加Odoo源:http://nightly.odoo.com/ deb http://nightly.odoo.com/8.0/nightly/deb/ ./ 2. sudo apt-get update 更新源列表,此过程中可能碰到key验证失败的问题,可到https://nightly.odoo

Odoo 二次开发教程(二)-模块的基础构建

注:本篇及后续均以8.0为基础. 一. Odoo模块的构成 __init__.py 文件是python包导入所必须的文件,内容可以为空,通常情况下我们用来导入自己写的py文件. __openerp__.py odoo模块的必须文件,里边包含了关于本模块的一些基础信息,如,依赖,视图文件等等. static文件夹 存放模块图标.静态文件的地方,js和qweb视图也放于此文件夹内. test 单元测试的相关文件 views 一些区分的比较清楚的模块会将view文件单独存放起来,并起一个名字,但这并非

学习 MeteoInfo二次开发教程(一)

来自气象家园:http://bbs.06climate.com/forum.php?mod=viewthread&tid=6631 按照教程,没有太大问题,有些是对c#操作不熟悉导致. 1.添加dll类库引用 建立项目后,在"解决方案资源管理器"中,右键"引用",点击"添加引用",右下角"浏览",找到需要引用的MeteoInfoC.dll文件,点击确认. 2.添加类库中的控件 点击左侧栏"工具箱",

学习 MeteoInfo二次开发教程(二)

1.注意TSB_Select_Click等几个名称要改为toolStripButton2_Click等. 2.以下代码的位置与public Form1()函数并行. 1 ToolStripButton _currentTool; 2 private void SetCurrentTool(ToolStripButton currentTool) 3 { 4 if (!(_currentTool == null)) 5 { 6 _currentTool.Checked = false; 7 } 8

学习 MeteoInfo二次开发教程(三)

1.breakList的问题 ((PolygonBreak) aLS.breakList[0]).DrawFill=false; 新的类库将LegendScheme的breakList属性改为了LegendBreaks,应该这样用: ((PolygonBreak)aLS.LegendBreaks[0]).DrawFill = false; 2.Offset的问题 1 cityLayer.LabelSet.Offset = 0; 2 需要改为以下两句: 3 cityLayer.LabelSet.X