通过对exo cms portal, Mambo以及IBM的CMS也深入研究,我决定要取它们的长处,利用他们的思想,但是要简化
它们的设计。针对cms里面非常重要的前台导航,我采用以下的设计方法
/* 前台内容节点设计
note_type: 路径=0,节点=1
content_type: 静态html=1,动态脚本=2
use_layout : 是否使用布局文件,就是类似于sitemesh一样的布局,使用它可以免去定义头,脚和导航菜单
*/
CREATE TABLE TBL_CMS_NODE (
node_id int(11) unsigned NOT NULL default '0',
label varchar(255) NOT NULL default '',
path varchar(255) NOT NULL default '',
name varchar(255) NOT NULL default '',
parent_node_id int(11) NOT NULL default '0',
node_type char(1) NOT NULL default '',
content_type char(1) NOT NULL default '',
use_layout char(1) NOT NULL default '',
layout varchar(10) NOT NULL default '',
PRIMARY KEY (node_id)
) TYPE=InnoDB;
INSERT INTO TBL_CMS_NODE VALUES (1, 'index', '/', '首页', '0','1','2','n','');
INSERT INTO TBL_CMS_NODE VALUES (2, 'xxjj', '/', '学校简介', '0','0','' ,'' ,'');
INSERT INTO TBL_CMS_NODE VALUES (3, 'index', '/xxjj/', '学校简介首页','2','1','1','y','wrap');
INSERT INTO TBL_CMS_NODE VALUES (4, 'xxgk', '/xxjj/', '学校概况', '2','1','1','y','wrap');
INSERT INTO TBL_CMS_NODE VALUES (5, 'xxdt', '/xxjj/', '学校动态', '2','0','' ,'' ,'');
INSERT INTO TBL_CMS_NODE VALUES (4, 'index', '/xxjj/xxdt/', '学校动态首页文章列表', '5','1','2','y','wrap');
INSERT INTO TBL_CMS_NODE VALUES (4, 'n', '/xxjj/xxdt/', '学校动态文章', '5','1','2','y','wrap');
/*
"/cms" 下解析的Use Case
1. /cms/ 没有文件后缀的,补上index.html
2. /cms/index.html 找到路径/ 下的index
3. /cms/xxjj/index.html 找到路径/xxjj/ 下的index
4. /cms/xxjj/xxgk.html 找到路径/xxjj/ 下的xxgk
5. /cms/xxjj/xxdt/index.html 找到路径/xxjj/xxdt/ 下的index
6. /cms/xxjj/xxdt/index_1.html 找到路径/xxjj/xxdt/ 下的index,把pageno=1做为一个变量放在context里面
7. /cms/xxjj/xxdt/n00000001.html 找到路径/xxjj/xxdt/ 下的n,把00000001作为一个变量article_id=0000001放在context里面
*/