前言:为方便互联网数万Discuz!爱好者,更加深入了解Discuz!软件,本人在熟悉Discuz!过程中,顺便将个人经验写给大家。本贴内容由本人定期更新。本贴只介绍Discuz!中部分技术点,本贴紧属个人观点,不足之处,请各位多多指教,在下先此谢过!。“Discuz!”在下文中简称“DZ”。要弄DZ二次开发,必须至少具备如下技能:
1) 能够理很好理解MVC构架的原理(虽然DZ不是MVC架构的)
2) 扎实的PHP基础,熟悉结构化程序,OOP程序的写法及应用
dz模板安装教程3) 熟悉MYSQL就用,掌握SQL语言,懂SQL优化者更佳
4) 熟悉使用Discuz!的各项功能
一) Discuz!的文件系统目录
注:想搞DZ开发,就得弄懂DZ中每个文件的功能。
a) Admin:后台管理功能模块
b) Api:DZ系统与其它系统之间接口程序
c) Archiver:DZ中,用以搜索引擎优化的无图版
d) Attachments:DZ中 ,用户上传附件的存放目录
e) Customavatars:DZ中,用户自定义头像的目录
f) Forumdata:DZ缓存数据的存放目录
g) Images:DZ模板中的图片存放目录
h) Include:DZ常用函数库,基本功能模块目录
i) Ipdata:DZ统计IP来路用的数据
j) Plugins:DZ插件信息的存放目录
k) Templates:DZ模板文件的存放目录
l) Wap:DZ无线,Wap程序处理目录
二) 必须记熟Discuz!数据库设计的每个表的功能,每个表中每个字段的功能。
关于DZ数据库设计文档,请参阅DZ相关的项目文档(请从本贴附件中下载)
三) Discuz!的流程控制
a) 后台流程控:DZ后台所有的功能,均需要注册到admincp.php文件,每个功能都至少有一个或一个以上的Action(动作),在admincp.php中,可以定义Action的执行权限,分别为:“admin==1”管理员,或“admin==2 || admin==3”超级版主和版主,每个Action对应一个脚本文件,脚本文件的命名为action.inc.php(*.inc.php),并存放在admin目录下,如执行:admincp.php?action=dodo,相当于执行admin目录下的dodo.inc.php文件
b) 前台流程控制:前台的流程控制比较简单:流程是自由的,如:
首页:index.php
会员注册:register.php;
会员登录:logging.php
发贴程序:post.php
会员信息:member.php
论坛内容:forumdisplay.php
查看贴子:viewthread.php
…大部分功能,此处不一一列出…
c) DZ根目下的config.inc.php属于整个DZ系统的配置文件
四) Discuz!的数据处理过程
a) DZ对mysql的数据库操作处理全部封装在dbstuff(db_mysql.class.php)类中
b) 所在的外部数据均通过“daddslashes()”初步过滤,然后再过滤,再根据需要处理
五) Discuz!的显示控制(网站多样式风格输出)
a) 显示层就是大家通常所看到的网站风格了。DZ中每套风络分别在templates及images下对应一个风格文件的存放目录。网站风格的制作,请参阅详细的
DZ风格制作文档
b) DZ网站风格文件处理的原理:其实很简单,DZ使用template.func.php中的parse_template()以PHP正则运算把htm模文件中的模板标签,转换成了PHP代码,并根据styleid保存在forumdata/templates下,这个有点像Smarty中的技术。
六) DZ中的语言处理
a) DZ前台及后台中、英语言的实现,均是把语句定义成了语变量,然后在模板输入,语句变量的赋值,均放在模板目录中的*.lang.php文件中,DZ在生成网站风格时就加载了这相应的语言包。
七) DZ如何处理用户信息(存取、计算、更新过程)
新手要做二次开发,都必须掌握这数组中,每个数组元素的意义。
a) DZ的基本信息,如用户信息,Session信息存在如下变量中:
a). $_DCACHE
b). $_COOKIE
c). $_DCOOKIE
d). $_DSESSION
e). $_DPLUGIN
b) 可以通过print_r($GLOBALS),打印全部变量
八) DZ中缓存处理机制
a) DZ中缓存处理过程都放在“cache.func.php”中,DZ的缓存处理比较简单,其原理是把一个数组转换成了PHP代码,并保存在缓存目录下,大家可打开缓存文件查看便知。
b) 使用方法:如果在新开的功能中,需要缓存某部分数据,基本上就是:
1)定义并注册缓存名字。
2)从数据读取相应的数据。
3)数据在写入缓存前作相应处理。
4)最后写入缓存。
具体操作,可以看文件中的代码,做相应的修改即可
九) DZ中模板处理机制
a) DZ独创的模板处理技术,类似于Smarty中的模板处理,只是具体算法,过程不同,Smarty是一种重型模板引擎方案。其原理都是把模板中的变量转换成相应的PHP代码,这个过程实际是模访JAVA中的一次编译,多处运行。
十) DZ中权限处理机制
a) 对于DZ中前台的每相action都有$discuz_action定义,DZ根据用户所在的用户组来判定用户是否具有相应操作$discuz_action的权限。至于后台的权限权验证,则更简单了,依据“admin==1”来确定的
十一) DZ中如何实现URL静态化
a) DZ中的静态有两法,只要懂ReWrite规划的朋友,一看就知。
十二) DZ独创的HTML编辑器,如何截取并使用,如果进行Discuz!代和Html代码的转换
a) 这也算是DZ比较牛的一项技术了,在早期版中,因DZ编辑器的不足,使得很多用户放弃了DZ。实现原理:通过JS把用的一些操作转换成了DZ的bbcode代码。这样子提交了安全性,将带有bbcode代码的内容存入数据,在用户打开页页时,又把bbcode代码转换成html代码
本贴声明:由于时间有限,本贴只有关于DZ部分功能的简短分析。若各位网友,对本文感兴趣并想更为深入了解DZ,请在本贴后回贴!我将尽可能多的DZ技术分析写在本文,不断更新本贴内容。
部分文件说明:
admincp.php 管理
ajax.php ajax功能
announcement.php
公告
attachment 附件
board.php 真正的首页
config.inc.php 这个是配置文件
corpus.php 论坛文集
digest.php 精华帖子
discuz_version.php 论坛版本号
faq.php 问题列表
forumdisplay.php 论坛列表
index.php 跳转页面
loggin.php 认证页面(登录退出)
mail_config.inc.php 邮件配置
member.php 用户操作
memcp.php 个人控制面版
misc.php 零碎功能
my.php 我的帖子
plugin.php 插件
pm.php 短信
post.php 发送帖子
redirect.php 页面重定向
register.php 注册
< 限制搜索
rss.php rss信息发布
search.php 论坛查询
secode.php 验证码
stats.php 统计
topic.php 首页论坛专题
topicadmin 主题管理
viewpro.php 显示个人信息
viewthread.php 主题显示
文件夹
admin 管理
api 接口
archiver 文档
attachments 附件
customavatars 自定义表情
forumdata 论坛数据包含缓冲数据
images 图片
include 公共文件
install 安装包
ipdata ip地址
plugins 插件
readme 帮助文档
templates 模板
utilities 工具包
wap 手机网站
文件夹include
advertisements.inc.php 广告管理
ajax.js ajax相关
attachment.func.php 附件函数集
bbscode.js 论坛表情
cache.fun.php 缓存函数集
category.inc.php 栏目
chinese.class.php
common.inc.php 最主要的头文件
common.js 最主要的js文件
corpus.func.php 论坛文集函数
counter.inc.php 论坛计数
cron.func.php 计划任务
db_mysql.class.php 数据库
db_mysql_error.inc.php 数据库错误
debug.php 调试信息
discuzcode.func.php 论坛代码
editor.func.php 编辑器
editor.js 编辑器
editpost.inc.php 编辑帖子
floatadv.js 浮动广告
forum.func.php 论坛函数集
global.func.php 全局函数
menu.js 菜单
misc.func.php 其它
newreply.inc.php 新回复
newthread.inc.php 新主题
*pmprompt.inc.php
post.fun.php 发表主题
printable.inc.php 论坛打印
qihoo.js qihoo
relatethreads.inc.php 相关主题
security.inc.php 安全
sendmail.inc.php 邮件
serverbusy.htm 系统繁忙
template.func.php 模板
threadpay.inc.php 购买帖子
-
----------------------------数据库----------------------------------------------------------------
db_access 用户权限表
cdb_adminactions 管理动作表
cdb_admingroups 管理组数据表
cdb_adminnotes 管理员留言
cdb_adminsessions 管理员后台在线记录
cdb_advertisements 广告资料表
cdb_announcements 论坛公告资料表
cdb_attachments 附件资料表
cdb_attachtypes 附件类型表
cdb_banned 被禁止的ip列表
cdb_bbcodes bb代码资料表
cdb_blogcaches 博客缓存表
cdb_buddys 好友信息表
cdb_creditslog 积分交易记录表
cdb_crons 计划任务表
cdb_failedlogins 错误登录记录
cdb_favorites 个人收藏信息表
cdb_forumfields 板块扩展信息数据表
cdb_forumlinks 友情链接数据表
cdb_forums 版块资料表
cdb_medals 勋章资料表
cdb_memberfields 用户扩展资料表
cdb_members 用户基本资料表
cdb_moderators 版主信息数据表
cdb_modworks 版主工作记录表
cdb_onlinelist 在线列表定制
cdb_onlinetime 用户在线时间信息表
cdb_orders 订单数据表
cdb_paymentlog 支付记录
cdb_pluginhooks 插件钩子表
cdb_plugins 插件表
cdb_pluginvars 插件配置表
cdb_pms 短信资料表
cdb_pmsearchindex 短消息搜索缓存表
cdb_polls 投票帖资料表
cdb_posts 帖子资料表
cdb_profilefields 用户栏目定制
cdb_promotions 论坛推广
cdb_ranks 头衔表
cdb_ratelog 帖子评分记录表
cdb_regips 注册ip记录表
cdb_relatedthreads 相关主题
cdb_rsscaches RSS缓存
cdb_searchindex 搜索缓存
cdb_sessions 在线表
cdb_settings 论坛设置表
cdb_smilies 表情信息表
cdb_stats 统计数据表
cdb_statvars 统计变量表
cdb_styles 风格
cdb_stylevars 风格变量表
cdb_subscrīptions 订阅信息表
cdb_templates 模板
cdb_threads 主题资料表
cdb_threadsmod 主题管理记录表
cdb_threadtypes 主题分类表
cdb_usergroups 用户组数据表
cdb_validating 等待人工审核的会员记录
cdb_words 词语过滤表
==================部份表解析=====
-- 表的结构 `cdb_access`
--
DROP TABLE IF EXISTS cdb_access;
CREATE TABLE cdb_access (
uid mediumint(8) unsigned NOT NULL default '0',
fid smallint(6) unsigned NOT NULL default '0',
allowview tinyint(1) NOT NULL default '0',
allowpost tinyint(1) NOT NULL default '0',
allowreply tinyint(1) NOT NULL default '0',
allowgetattach tinyint(1) NOT NULL default '0',
allowpostattach tinyint(1) NOT NULL default '0',
PRIMARY KEY (uid,fid)
) TYPE=MyISAM;
--
--
数据表说明:当某用户对某些版块有特定的权限的时候,该表记录了该用户在这些版块有什么权限。
属性说明:
uid--mediumint(8)--会员的UID编号
fid--smallint(6)--版块的ID号
allowview--tinyint(1)--是否允许查看贴子
allowpost--tinyint(1)--是否允许发贴
allowreply--tinyint(1)--是否允许回复
allowgetattach--tinyint(1)--是否允许下载附件
allowpostattach tinyint(1) --是否允许上传附件
--
-- 表的结构 `cdb_adminactions`
--
DROP TABLE IF EXISTS cdb_adminactions;
CREATE TABLE cdb
_adminactions (
admingid smallint(6) unsigned NOT NULL default '0',
disabledactions text NOT NULL,
PRIMARY KEY (admingid)
) TYPE=MyISAM;
--
数据表功能介绍:管理组管理信息表。
admingid smallint(6)--管理组组id
disabledactions text--禁止行为
-
------------------------------------------------------------------------------------------------------------------------------------
-- 表的结构 `cdb_admingroups`
--
DROP TABLE IF EXISTS cdb_admingroups;
CREATE TABLE cdb_admingroups (
admingid smallint(6) unsigned NOT NULL default '0',
alloweditpost tinyint(1) NOT NULL default '0',
alloweditpoll tinyint(1) NOT NULL default '0',
allowstickthread tinyint(1) NOT NULL default '0',
allowmodpost tinyint(1) NOT NULL default '0',
allowdelpost tinyint(1) NOT NULL default '0',
allowmassprune tinyint(1) NOT NULL default '0',
allowrefund tinyint(1) NOT NULL default '0',
allowcensorword tinyint(1) NOT NULL default '0',
allowviewip tinyint(1) NOT NULL default '0',
allowbanip tinyint(1) NOT NULL default '0',
allowedituser tinyint(1) NOT NULL default '0',
allowmoduser tinyint(1) NOT NULL default '0',
allowbanuser tinyint(1) NOT NULL default '0',
allowpostannounce tinyint(1) NOT NULL default '0',
allowviewlog tinyint(1) NOT NULL default '0',
disablepostctrl tinyint(1) NOT NULL default '0',
PRIMARY KEY (admingid)
) TYPE=MyISAM;
--
数据表功能介绍:管理模组信息表。
admingid--smallint(3)--管理组的ID
alloweditpost tinyint(1)--编辑帖子权限
alloweditpoll tinyint(1)--编辑投票权限
allowstickthread tinyint(1)--置顶帖子权限
allowmodpost tinyint(1)--管理(编辑)帖子权限
allowdelpost tinyint(1)--删除帖子权限
allowmassprune tinyint(1)--阅读权限
allowrefund tinyint(1)--
allowcensorword tinyint(1)--过滤词语设置权限
allowviewip tinyint(1)--查看ip权限
allowbanip tinyint(1)--禁止ip权限
allowedituser tinyint(1)--编辑用户权限
allowmoduser tinyint(1)--管理用户权限
allowbanuser tinyint(1)--禁止用户权限
allowpostannounce tinyint(1)--发表公告权限
allowviewlog tinyint(1)--浏览管理日志权限
disablepostctrl tinyint(1)--批量管理权限
------------------------------------------------------------------------------------------
-
- 表的结构 `cdb_adminnotes`
--
DROP TABLE IF EXISTS cdb_adminnotes;
CREATE TABLE cdb_adminnotes (
id mediumint(8) unsigned NOT NULL auto_increment,
admin varchar(15) NOT NULL default '',
access tinyint(3) NOT NULL default '0',
adminid tinyint(3) NOT NULL default '0',
dateline int(10) unsigned NOT NULL default '0',
expiration int(10) unsigned NOT NULL default '0',
message text NOT NULL,
PRIMARY KEY (id)
) TYPE=MyISAM;
--
数据表功能介绍:后台留言信息。
id mediumint(8)--事件id
admin varchar(15)--操作者
access tinyint(3)--
adminid tinyint(3)--
管理组id
dateline int(10)--日期
expiration int(10)--有效期
message text--留言内容
-------------------------------------------------------------------------
-- 表的结构 `cdb_adminsessions`
--
DROP TABLE IF EXISTS cdb_adminsessions;
CREATE TABLE cdb_adminsessions (
uid mediumint(8) unsigned NOT NULL default '0',
ip char(15) NOT NULL default '',
dateline int(10) unsigned NOT NULL default '0',
errorcount tinyint(1) NOT NULL default '0'
) TYPE=MyISAM;
-
-
数据表功能介绍:后台登录记录
uid mediumint(8) --用户登录id
ip char(15)--登录ip
dateline int(10)--登录日期
errorcount tinyint(1)--密码错误次数
--------------------------------------------------------------------------
-- 表的结构 `cdb_advertisements`
--
DROP TABLE IF EXISTS cdb_advertisements;
CREATE TABLE cdb_advertisements (
advid mediumint(8) unsigned NOT NULL auto_increment,
available tinyint(1) NOT NULL default '0',
`type` varchar(50) NOT NULL default '0',
displayorder tinyint(3) NOT NULL default '0',
title varchar(50) NOT NULL default '',
targets text NOT NULL,
parameters text NOT NULL,
`code` text NOT NULL,
starttime int(10) unsigned NOT NULL default '0',
endtime int(10) unsigned NOT NULL default '0',
PRIMARY KEY (advid)
)
TYPE=MyISAM;
--
数据表功能介绍:广告信息存储
advid mediumint(8)--广告id
available tinyint(1)--是否显示(可用)
`type` varchar(50)--类型
displayorder tinyint(3)--显示顺序
title varchar(50)--标题
targets text --样式
parameters text--展放位置#
`code` text--代码
starttime int(10) --开始时间
endtime int(10)--结束时间
------------------------------------------------------------==================
-- 表的结构 `cdb_announcements`
--
DROP TABLE IF EXISTS cdb_announcements;
CREATE TABLE cdb_announcements (
id smallint(6) unsigned NOT NULL auto_increment,
author varchar(15) NOT NULL default '',
`subject` varchar(250) NOT NULL default '',
displayorder tinyint(3) NOT NULL default '0',
starttime int(10) unsigned NOT NULL default '0',
endtime int(10) unsigned NOT NULL default '0',
message text NOT NULL,
PRIMARY KEY (id),
KEY timespan (starttime,endtime)
) TYPE=MyISAM;
--
数据表功能介绍:公告信息存储
id smallint(6)--公告id
author varchar(15)--发布者
`subject` varchar(250)--标题
displayorder tinyint(3)--显示顺序
starttime int(10)--开始时间
endtime int(10) --结束时间
message text--内容
--------------------------------------------------------------------------------------
-- 表的结构 `cdb_attachments`
--
DROP TABLE IF EXISTS cdb_attachments;
CREATE TABLE cdb_attachments (
aid mediumint(8) unsigned NOT NULL auto_increment,
tid mediumint(8) unsigned NOT NULL default '0',
pid int(10) unsigned NOT NULL default '0',
dateline int(10) unsigned
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论