帝国CMS二次开发入门教程

本篇主要讲解帝国CMS二次开发入门教程,学会了你就会大致知道帝国CMS二次开发从何入手了。首先在说帝国CMS二次开发之前,我们得先了解帝国CMS目录结构和常用的自带函数。
帝国CMS目录结构
系统根目录
├d/ 附件和数据存放目录 (data)
│├file/ 附件存放目录
│├js/ JS调用生成目录
│└txt/ 内容存文本存放目录
├e/ 系统程序目录 (empire)
├html/ 自定义内容页存放预设目录
├images/ 默认模板图片目录
├s/ 专题目录 (special)
├search/ 高级搜索页面目录
├skin/ 模板CSS和图片存放目录
├testdata/ 内置测试数据的附件目录 (安装时选择测试数据用的,不内置测试数据可以删除)
└index.html 网站首页
/e/ 系统程序目录
├action/ 信息动态列表页和内容页目录
├admin/ 后台目录 (可重命名)
├class/ 系统核心文件目录
├data/ 系统处理数据相关目录 (临时文件、缓存等)
├DoInfo/ 前台会员管理信息目录 (页面模板e/template/DoInfo)
├DoPrint/ 打印页面目录
├DownSys/ 下载系统模型功能目录 (页面模板e/template/DownSys)
├enews/ 前台处理数据入口文件
├extend/ 扩展程序目录
├ftp/ FTP识别目录
├install/ 安装程序目录,安装后请删除掉
├member/ 前台会员功能目录 (页面模板e/template/member)
├message/ 提示信息页面目录
├NewsSys/ 新闻系统模型功能目录
├payapi/ 在线支付接口目录 (页面模板e/template/payapi)
├pl/ 评论页目录
├public/ 公用功能程序目录 (页面模板e/template/public)
├sch/ 全站全文搜索生成目录
├search/ 普通搜索文件目录
├ShopSys/ 商城系统模型功能目录 (页面模板e/template/ShopSys)
├ShowKey/ 前台验证码文件目录
├space/ 会员空间目录 (其中template为会员空间模板目录)
├tags/ TAGS列表文件目录
├tasks/ 计划任务脚本存放目录
├template/ 前台动态页的模板目录
├tool/ 插件相关功能目录 (页面模板e/template/tool)
├update/ 升级程序目录 (升级程序复制到这个目录运行)
├ViewImg/ 显示图片大图目录
├wap/ WAP功能目录 (其中template为WAP模板目录)
└web/ RSS显示文件目录
/e/template/ 动态页面模板目录
├DoInfo/ 前台投稿模板目录 (对应程序目录:/e/DoInfo/)
│├AddInfo.php 发布投稿页面模板 (对应程序文件:/e/DoInfo/AddInfo.php)
│├ChangeClass.php 发布投稿选择栏目页面模板 (对应程序文件:/e/DoInfo/ChangeClass.php)
│├DoInfo.php 管理投稿首页页面模板 (对应程序文件:/e/DoInfo/index.php)
│└tran.php 发布投稿上传附件页面模板 (对应程序文件:/e/DoInfo/tran.php)
├DownSys/ 下载模型页面模板目录 (对应程序目录:/e/DownSys/)
│└report.php 提交错误报告页面模板 (对应程序文件:/e/report/index.php)
├member/ 会员中心模板目录 (对应程序目录:/e/member/)
│├memberlist/ 会员列表页面模板目录 (对应程序文件:/e/member/list/index.php)
│├mspace/ 管理会员空间页面模板目录 (对应程序目录:/e/member/mspace/)
││├ChangeStyle.php 选择空间模板页面模板 (对应程序文件:/e/member/mspace/ChangeStyle.php)
││├feedback.php 管理会员空间反馈页面模板 (对应程序文件:/e/member/mspace/feedback.php)
││├gbook.php 管理会员空间留言页面模板 (对应程序文件:/e/member/mspace/gbook.php)
││├ReGbook.php 管理会员空间留言回复页面模板 (对应程序文件:/e/member/mspace/ReGbook.php)
││├SetSpace.php 设置会员空间页面模板 (对应程序文件:/e/member/mspace/SetSpace.php)
││└ShowFeedback.php 管理会员空间反馈显示反馈页面模板 (对应程序文件:/e/member/mspace/ShowFeedback.php)
│├AddFava.php 增加收藏页面模板 (对应程序文件:/e/member/fava/add/index.php)
│├AddFriend.php 增加好友页面模板 (对应程序文件:/e/member/friend/add/index.php)
│├AddMsg.php 发送站内信息页面模板 (对应程序文件:/e/member/msg/AddMsg/index.php)
│├buybak.php 购买记录页面模板 (对应程序文件:/e/member/buybak/index.php)
│├buygroup.php 购买充值类型页面模板 (对应程序文件:/e/member/buygroup/index.php)
│├card.php 点卡充值页面模板 (对应程序文件:/e/member/card/index.php)
│├ChangeFriend.php 选择好友页面模板 (对应程序文件:/e/member/friend/FriendClass/index.php)
│├ChangeRegister.php 选择注册会员组页面模板 (对应程序文件:/e/member/register/ChangeRegister.php)
│├cp.php 会员中心首页页面模板 (对应程序文件:/e/member/cp/index.php)
│├downbak.php 消费记录页面模板 (对应程序文件:/e/member/downbak/index.php)
│├EditInfo.php 修改资料页面模板 (对应程序文件:/e/member/EditInfo/index.php)
│├EditSafeInfo.php 修改安全资料页面模板 (对应程序文件:/e/member/EditInfo/EditSafeInfo.php)
│├fava.php 管理收藏页面模板 (对应程序文件:/e/member/fava/index.php)
│├FavaClass.php 管理收藏分类页面模板 (对应程序文件:/e/member/fava/FavaClass/index.php)
│├friend.php 管理好友页面模板 (对应程序文件:/e/member/friend/index.php)
│├FriendClass.php 管理好友分类页面模板 (对应程序文件:/e/member/friend/FriendClass/index.php)
│├getpass.php 取回密码重置页面模板 (对应程序文件:/e/member/GetPassword/getpass.php)
│├GetPassword.php 取回密码页面模板 (对应程序文件:/e/member/GetPassword/index.php)
│├login.php 会员登录页面模板 (对应程序文件:/e/member/login/index.php)
│├loginopen.php 弹出页面提示重新登陆页面模板 (对应程序文件:/e/member/login/login.php)
│├msg.php 管理站内信息页面模板 (对应程序文件:/e/member/msg/index.php)
│├my.php 我的状态页面模板 (对应程序文件:/e/member/my/index.php)
│├register.php 会员注册页面模板 (对应程序文件:/e/member/register/index.php)
│├regsend.php 注册激活帐号页面模板 (对应程序文件:/e/member/register/regsend.php)
│├ShowInfo.php 查看会员资料页面模板 (对应程序文件:/e/member/ShowInfo/index.php)
│└ViewMsg.php 查看站内信息内容页面模板 (对应程序文件:/e/member/msg/ViewMsg/index.php)
├payapi/ 在线支付页面模板目录 (对应程序目录:/e/payapi/)
│└payapi.php 在线支付页面模板 (对应程序文件:/e/payapi/index.php)
├public/ 公共程序页面模板目录 (对应程序目录:/e/public/)
│└vote.php 信息投票结果页面模板 (对应程序文件:/e/public/vote/index.php)
├ShopSys/ 商城模型页面模板目录 (对应程序目录:/e/ShopSys/)
│├buycar.php 购物车页面模板 (对应程序文件:/e/ShopSys/buycar/index.php)
│├ListDd.php 管理商城订单页面模板 (对应程序文件:/e/ShopSys/ListDd/index.php)
│├order.php 订单提交表单页面模板 (对应程序文件:/e/ShopSys/order/index.php)
│├ShowDd.php 查看商城订单内容页面模板 (对应程序文件:/e/ShopSys/ShowDd/index.php)
│└SubmitOrder.php 订单提交最终确认页面模板 (对应程序文件:/e/ShopSys/SubmitOrder/index.php)
└tool/ 内置插件模板目录 (对应程序目录:/e/tool/)
└vote.php 投票插件结果页面模板 (对应程序文件:/e/tool/vote/index.php)

帝国CMS常用函数介绍
常用函数可以帮助你解决许多问题,学会了让你少写几千行代码。

一、esub()截取字段函数
语法:esub(字符串,截取字数,后缀)
说明:后缀为截取字符后附带内容,此参数可以省略。
使用范例:

,返回结果为:123456 ,返回结果为:123456...

二、date()转换时间格式函数
语法:date(时间格式,时间戳)
说明:PHP本身函数,使用说明可以参考:http://cn.php.net/manual/en/function.date.php
使用范例:

,返回结果为:2010-06-30 10:30:10

三、format_datetime()转换时间格式函数2
语法:format_datetime(正常时间,时间格式)
说明:和date()的区别是format_datetime是转换正常时间,而date是转换unix时间戳。
使用范例:

,返回结果为:06/30

四、通过ID取得栏目地址函数
语法:sys_ReturnBqClassname( r , 9 ) 说 明 : r,9) 说明: r,9)r为含栏目ID的数组,变量名可任意命名。
使用范例:取得栏目ID=2的栏目地址。

通过ID取得栏目地址的其他方法:
(1)、/e/public/ClassUrl/?classid=栏目ID
(2)、/
五、取得信息内容页地址函数
语法:sys_ReturnBqTitleLink( r ) 说 明 : r) 说明: r)r为含“id,classid,newspath,filename,groupid,titleurl”字段内容的数组,变量名可任意命名。
使用范例:取得信息ID=8的新闻页面地址

fetch1("select id,classid,newspath,filename,groupid,titleurl from {$dbtbpre}ecms_news where id='8' limit 1"); $titleurl=sys_ReturnBqTitleLink($nr); echo $titleurl; ?>

通过ID取得信息内容页地址的其他方法:
/e/public/InfoUrl/?classid=栏目ID&id=信息ID
六、提示信息函数1
语法:printerror( e r r o r , error, error,gotourl, e c m s , ecms, ecms,noautourl,$novar)
说明:
$error:提示信息内容,可以为语言包变量,也可以直接提示内容。
$gotourl:提示信息转向链接地址
$ecms:0为后台提示信息、1为前台提示信息、8为后台提示信息(alert方式)、9为前台提示信息(alert方式)
$noautourl:0为自动转向页面,1为不自动转向页面。此参数可省略,默认为0
n o v a r : 0 为 提 示 信 息 内 容 采 用 语 言 包 变 量 , 1 为 提 示 信 息 内 容 为 直 接 提 示 内 容 。 此 参 数 可 以 省 略 , 默 认 为 0 使 用 范 例 : p r i n t e r r o r ( ′ D b E r r o r ′ , ′ h t t p : / / w w w . p h o m e . n e t ′ , 1 ) , 前 台 提 示 , 提 示 信 息 内 容 为 语 言 包 D b E r r o r 变 量 内 容 , 转 向 帝 国 网 站 p r i n t e r r o r ( ′ 数 据 库 出 错 ′ , ′ h t t p : / / w w w . p h o m e . n e t ′ , 1 , 0 , 1 ) , 前 台 提 示 , 提 示 信 息 内 容 为 “ 数 据 库 出 错 ” , 转 向 帝 国 网 站 附 加 说 明 : 此 函 数 需 结 合 novar:0为提示信息内容采用语言包变量,1为提示信息内容为直接提示内容。此参数可以省略,默认为0 使用范例: printerror('DbError','http://www.phome.net',1),前台提示,提示信息内容为语言包DbError变量内容,转向帝国网站 printerror('数据库出错','http://www.phome.net',1,0,1),前台提示,提示信息内容为“数据库出错”,转向帝国网站 附加说明: 此函数需结合 novar010使printerror(DbError,http://www.phome.net,1)DbErrorprinterror(,http://www.phome.net,1,0,1)editor变量来确定目录层次。默认 e d i t o r 变 量 为 0 。 当 程 序 文 件 在 / e / p a t h / 目 录 , editor变量为0。 当程序文件在/e/path/目录, editor0/e/path/editor不用设置,也就是用默认0。
当程序文件在/e/path/path2/目录, e d i t o r = 1 。 当 程 序 文 件 在 / e / p a t h / p a t h 2 / p a t h 3 / 目 录 , editor=1。 当程序文件在/e/path/path2/path3/目录, editor=1/e/path/path2/path3/editor=2。
当程序文件在/e/path/path2/path3/path4/目录, e d i t o r = 3 。 七 、 提 示 信 息 函 数 2 ( 直 接 提 示 内 容 ) 语 法 : p r i n t e r r o r 2 ( editor=3。 七、提示信息函数2 (直接提示内容) 语法:printerror2( editor=32()printerror2(error, g o t o u r l , gotourl, gotourl,ecms,$noautourl)
说明:
$error:直接提示信息的内容。
$gotourl:提示信息转向链接地址
$ecms:0为默认提示信息方式、9为弹出提示信息方式(alert方式)。此参数可省略,默认为0
n o a u t o u r l : 0 为 自 动 转 向 页 面 , 1 为 不 自 动 转 向 页 面 。 此 参 数 可 省 略 , 默 认 为 0 使 用 范 例 : p r i n t e r r o r 2 ( ′ 添 加 完 毕 ′ , ′ h t t p : / / w w w . p h o m e . n e t ′ ) , 提 示 信 息 内 容 为 “ 添 加 完 毕 ” , 转 向 帝 国 网 站 附 加 说 明 : 此 函 数 不 需 要 结 合 其 他 变 量 , 可 以 在 任 意 目 录 层 次 使 用 。 不 支 持 使 用 语 言 包 变 量 。 八 、 设 置 系 统 C O O K I E 变 量 函 数 语 法 : e s e t c o o k i e ( noautourl:0为自动转向页面,1为不自动转向页面。此参数可省略,默认为0 使用范例: printerror2('添加完毕','http://www.phome.net'),提示信息内容为“添加完毕”,转向帝国网站 附加说明: 此函数不需要结合其他变量,可以在任意目录层次使用。不支持使用语言包变量。 八、设置系统COOKIE变量函数 语法:esetcookie( noautourl010使printerror2(,http://www.phome.net)使使COOKIEesetcookie(var, v a l , val, val,life,$ecms)
说明:
$var:为变量名
$val:为变量值
$life:为COOKIE有效时间,单位秒,0为不保存。此参数可省略,默认为不保存。
e c m s : 0 为 设 置 前 台 C O O K I E 变 量 , 1 为 设 置 后 台 C O O K I E 变 量 。 此 参 数 可 省 略 , 默 认 为 0 。 使 用 范 例 : e s e t c o o k i e ( ′ m y b o d y ′ , ′ 帝 国 ′ ) , 定 义 前 台 “ C O O K I E 前 缀 + m y b o d y ” 变 量 , 变 量 内 容 为 “ 帝 国 ” e s e t c o o k i e ( ′ m y b o d y ′ , ′ 帝 国 ′ , 0 , 1 ) , 定 义 后 台 “ C O O K I E 前 缀 + m y b o d y ” 变 量 , 变 量 内 容 为 “ 帝 国 ” 附 加 说 明 : 此 设 置 C O O K I E 函 数 会 给 变 量 名 加 上 C O O K I E 前 缀 , 你 可 也 可 以 直 接 用 P H P 本 身 的 s e t c o o k i e 来 定 义 。 九 、 取 得 系 统 C O O K I E 变 量 函 数 语 法 : g e t c v a r ( ecms:0为设置前台COOKIE变量,1为设置后台COOKIE变量。此参数可省略,默认为0。 使用范例: esetcookie('mybody','帝国'),定义前台“COOKIE前缀+mybody”变量,变量内容为“帝国” esetcookie('mybody','帝国',0,1),定义后台“COOKIE前缀+mybody”变量,变量内容为“帝国” 附加说明: 此设置COOKIE函数会给变量名加上COOKIE前缀,你可也可以直接用PHP本身的setcookie来定义。 九、取得系统COOKIE变量函数 语法:getcvar( ecms0COOKIE1COOKIE0使esetcookie(mybody,)COOKIE+mybodyesetcookie(mybody,,0,1)COOKIE+mybodyCOOKIECOOKIEPHPsetcookieCOOKIEgetcvar(var,$ecms)
说明:
$var:为变量名
e c m s : 0 为 设 置 前 台 C O O K I E 变 量 , 1 为 设 置 后 台 C O O K I E 变 量 。 此 参 数 可 省 略 , 默 认 为 0 。 使 用 范 例 : g e t c v a r ( ′ m l u s e r n a m e ′ ) , 取 得 前 台 登 陆 会 员 的 用 户 名 g e t c v a r ( ′ l o g i n u s e r n a m e ′ , 1 ) , 取 得 后 台 登 陆 管 理 员 的 用 户 名 附 加 说 明 : 此 取 得 C O O K I E 函 数 是 取 得 变 量 名 加 上 C O O K I E 前 缀 的 变 量 , 你 可 也 可 以 直 接 用 P H P 本 身 的 ecms:0为设置前台COOKIE变量,1为设置后台COOKIE变量。此参数可省略,默认为0。 使用范例: getcvar('mlusername'),取得前台登陆会员的用户名 getcvar('loginusername',1),取得后台登陆管理员的用户名 附加说明: 此取得COOKIE函数是取得变量名加上COOKIE前缀的变量,你可也可以直接用PHP本身的 ecms0COOKIE1COOKIE0使getcvar(mlusername)getcvar(loginusername,1)COOKIECOOKIEPHP_COOKIE[‘变量名’]来取得。
十、取得IP地址函数
语法:egetip()
使用范例:

十一、动态页面显示分页函数
语法:page1( n u m , num, num,line, p a g e l i n e , page_line, pageline,start, p a g e , page, page,search)
说明:
$num:总记录数
$line:每页显示数量
$page_line:每页显示分页链接数
$start:预设变量,设置0即可。
$page:当前页码(0为起始页码)
s e a r c h : 链 接 附 加 参 数 十 二 、 通 过 栏 目 I D 取 得 栏 目 名 和 栏 目 别 名 方 法 : 栏 目 名 : < ? = search:链接附加参数 十二、通过栏目ID取得栏目名和栏目别名方法: 栏目名:searchID<?=class_r[栏目ID][‘classname’]?>
栏目别名:

帝国CMS二次开发教程
二次开发教程在你了解以上内容后也非常简单,二次开发不需要你了解太多的PHP知识,但需要会一点SQL写法,常用的SQL查询语句都可以在网上找到。

帝国CMS二次开发语法范本

query("select * from {$dbtbpre}ecms_news order by newstime limit 10"); //查询新闻表最新10条记录 require('template/index.temp.php'); //导入模板文件 db_close(); //关闭MYSQL链接 $empire=null; //注消操作类变量 ?>

上面就是一个二次开发的范本了,链接数据库 然后查询信息,学会了你就会可以查询调用任何你需要调用的信息了,也可以彻底摆脱帝国CMS默认调用标签的束缚了。
本文转自迅雪网

你可能感兴趣的:(笔记)