FineCMS使用手册.docx
- 文档编号:27624859
- 上传时间:2023-07-03
- 格式:DOCX
- 页数:99
- 大小:684.07KB
FineCMS使用手册.docx
《FineCMS使用手册.docx》由会员分享,可在线阅读,更多相关《FineCMS使用手册.docx(99页珍藏版)》请在冰豆网上搜索。
FineCMS使用手册
FineCMS使用手册
一、主要功能模块2
二、安装及升级3
(一)环境需求3
(二)系统安装3
(三)系统升级4
三、使用说明5
(四)系统设置5
(五)系统安全5
(六)栏目管理6
(七)附件管理6
(八)内容管理7
(九)推荐位管理7
(十)文字块管理8
(十一)会员投稿流程9
四、功能教程10
(十二)模型使用说明10
(十三)字段类别说明12
(十四)[静态/伪静态]自定义URL地址详细教程16
(十五)生成静态教程19
(十六)表单使用教程22
(十七)Ucenter使用说明25
(十八)网站多语言配置方法27
(十九)后台管理目录(admin)更改方法介绍28
(二十)部分表的数据结构29
(二十一)自定义Tag标签的URL规则30
(二十二)站内搜索参数说明及表单设计31
(二十三)多站点及分站配置33
(二十四)会员扩展使用教程34
(二十五)FineCMS模板设计指南34
(二十六)FineCMS万能标签list功能介绍36
(二十七)标签语法说明43
(二十八)系统变量介绍45
(二十九)系统函数介绍46
(三十)关于栏目{$cats}调用说明47
五、进阶教程49
(三十一)FineCMS框架基础知识介绍49
(三十二)FineCMS的Model应用50
(三十三)FineCMS的View应用63
(三十四)FineCMS的Controller应用66
(三十五)FineCMS插件开发指南68
(三十六)自定义字段类别71
(三十七)自定义编辑器74
(三十八)个性化URL结构75
(三十九)表单模型和会员扩展模型中的回调函数用法77
(四十)数据读写分离配置79
FineCMS(简称FC)是一款基于PHP+MySql开发的内容管理系统,其中免费版是完全开源的版本,采用MVC设计模式实现业务逻辑与表现层的适当分离,使网页设计师能够轻松设计出理想的模板,插件化方式开发功能易用便于扩展,支持自定义内容模型和会员模型,并且可以自定义字段,可面向中小型站点提供重量级网站建设方案。
对于那些想要进行开发的技术不足,又南中羞涩的站长们是一个难得的CMS平台。
目前FC只有在线手册,使用起来有些不方便我对FC手册进行了整理,希望对各位有一定帮助。
一、主要功能
自定义模型和字段
超强的自定义模型和字段功能则把系统灵活度发挥到了极致,不用编程就实现各种信息发布和检索。
?
多站点及分站
支持多个站点管理及分站功能,多站只需绑定域名到根目录,使用相当方便。
多国语言支持
系统自带语言有简体中文、繁体中文、英文,其他语言扩展相当方便。
负载能力强
从缓存技术、数据库设计、代码优化等多个角度入手进行优化,支持百万级数据量。
模板制作方便
采用MVC设计模式实现了程序与模板完全分离,灵活的模板标签能完全显示全站信息。
?
支持文章内链
有助于提高搜索引擎对网站的爬行索引效率,支持Tag自动内链到文章。
表单功能
用于拓展内容模型和会员模型,如报名、评论、询价、咨询等。
推荐位功能
推荐位功能可以让编辑随时把信息推送至指定位置,操作简单实用。
文字块功能
把一些小段内容放在文字块中,支持HTML代码和图片上传。
自定义URL规则
可以完全自定义URL地址规则,包括栏目、内容及自定义页。
功能插件化
按照官方提供的插件为蓝本,用户可开发出属于自己的插件。
SEO处理
性化设置每个栏目的标题标签、描述标签、关键词标签,自动生成XX谷歌网站地图。
二、安装及升级
(一)环境需求
FineCMS居于PHP和MySQL技术开发,可同时使用于Windows、Linux、Unix平台,环境需求如下:
1、Windows平台
IIS/Apache+PHP5.2.x+MySQL4/5
2、Linux/Unix平台
Apache+PHP5.2.x+MySQL3/4/5(PHP必须在非安全模式下运行)
建议使用平台:
Linux+Apache2.2+PHP5.2.x+MySQL5.0
3、PHP必须环境或启用的系统函数
allow_url_fopen
GD扩展库
MySQL扩展库
JSON支持
4、基本目录结构
..../cache 程序缓存目录[必须有可写入权限]
..../config 系统配置文件目录[必须有可写入权限]
..../controllers系统控制器目录
..../core 系统核心程序目录
..../extensions系统扩展程序目录
..../models 系统模型文件存放目录[必须有可写入权限]
..../uploadfiles文件上传目录[必须可写入]
..../plugins 插件目录[必须可写入]
..../views 系统模板目录
(二)系统安装
1、解压FineCMS软件压缩包,将压缩包内FineCMS目录内的所有文件及目录上传至网站根目录。
3、根据安装向导提示设置必要的数据库连接参数以及必要的文件属性完成系统安装。
(三)系统升级
登录管理后台如果发现“系统信息”中出现“有新版本”提示,我们可以
方法一、重新下载程序(重新安装数据会重置)
下载地址:
。
方法二、安装在线升级插件(若无写入权限该插件无法完成升级)
如果您是linux服务器,需要将全站设置0777权限,否则无法解压覆盖。
方法三、下载更新程序(推荐)
地址:
注意:
升级包必须按版本顺序下载,解压后按版本顺序覆盖根目录,如果有sql文件,请导入到数据库中(注意修改表前缀哦)。
三、使用说明
(四)系统设置
一看就很简单,每一项都有说明的
(五)系统安全
一、存在多管理员账号建议开启“后台操作日志”(系统设置-系统相关)。
二、更改管理目录路径(默认admin)。
robots.txt文件中增加屏蔽地址技巧:
Disallow:
/index.php?
s=t*
Disallow:
/t*
表示以t开头的控制器或者目录禁止蜘蛛爬行,这样可以不暴露管理目录
三、开启“非法字符过滤”以及开启"攻击日志"(系统设置-系统相关)。
2、受到非法字符攻击时可以开启邮件通知(系统设置-系统相关-开启邮件通知,一定要设置”网站管理邮箱以及邮件服务器配置“哦)。
3、Ip禁止功能,若有非法字符攻击时系统会记录攻击者Ip、会员的id、受攻击页面、非法字符等信息,可以让其Ip禁止方法(系统设置-禁止访问)。
(六)栏目管理
如图所示,栏目管理相当方便,内部栏目有直接发布信息的链接。
栏目类型分为:
内部栏目(用于发布信息,必须绑定模型)、单网页(单独的一个页面)、外部链接(链接到外部的地址)。
(七)附件管理
file:
管理员用户文件上传的目录
image:
管理员用户图片上传的目录
member:
会员附件目录
(八)内容管理
操作方便,用户可以执行排序、删除、标记、移动、修改、发布等操作
(九)推荐位管理
1、推荐位列表操作
2、推荐位中的信息管理
3、添加推荐位内容(可以直接在内容表中提取内容)
(一十)文字块管理
把一些小段内容放在文字块中,支持HTML代码和图片上传
Tag标签管理
汉字标签自动转换为拼音,支持导入标签。
将标签加入到文章内容中(也就是文章的内链方式)。
1、更新标签缓存。
2、在”系统设置“-”Tag相关“开启”文档内容中关联“(选择”是“)即可。
3、如果文章使用的是生成静态,那么必须重新生成一次,伪静态会立即生效。
(一十一)会员投稿流程
1、会员/游客投稿流程
发布稿件->数据存入审核临时表(若会员组权限无需审核则直接发布)->管理员审核通过->发布内容表中(同时删除临时表数据)
2、会员修改文档流程
修改稿件->修改数据存入审核临时表->待管理员审核通过->更新内容表数据(同时删除临时数据)
修改稿件->修改数据存入审核临时表->被管理员审核拒绝->修改稿件被退回
四、功能教程
(一十二)模型使用说明
模型是FineCMS的核心,下面来介绍如何创建内容模型(会员模型、表单模型与内容模型一致)
一、添加一个模型
后台进入“内容模型”,执行“添加”
模型名称:
是你为这个模型取一个名字,比如”文章“,”产品“,”报表“
数据表名:
不能重复,小写英文即可,比如”news“,”pro“
栏目模板、列表模板、内容模板可以自定义,如果不填系统会自动给你取一个名字,必须是".html"文件
关于”关联表单“在表单章节有介绍
二、字段管理,添加字段
1、进入“模型列表”,执行“字段管理”,见下图
2、可以看到默认的系统字段,你可以对默认的系统字段进行修改,见下图
3、执行菜单上的“添加”,来为当前模型添加字段,见下图
字段别名:
当然这个别名指的是字段的标题,比如:
文章标题,电话号码等
字段名称:
只能由英文字母、数字和下划线组成,并且仅能字母开头,不以下划线结尾
字段类别:
根据实际情况来选择(实在不懂的可以参考”字段类别说明“这一节)
字段类型:
根据你的情况来设定字段类别,就行mysql建表字段一样
字段长度:
由上面的“字段类型”来决定长度,不能超过了该字段类型的最大长度,不了解可以翻翻Mysql手册
字段索引:
提供了普通、唯一两种索引(不熟悉索引的朋友不要随便选择此项)
字段提示:
提示这个字段是用来干什么的
前台显示:
该字段在会员投稿的时候显示,选择了“隐藏”,会员投稿就不会显示了
必填字段:
这里可以对字段进行有效性验证,比如简单的正则等
(一十三)字段类别说明
一、字段类别说明
1、单行文本(input)
①、参数说明
长度:
文本框的width值,以px为单位
②、调用方法
{$字段名称}
2、多行文本(textarea)
①、参数说明
宽度:
文本框的width值,以px为单位
高度:
文本框height值,以px为单位
②、调用方法
{$字段名称}
3、下拉选择框(select)
①、参数说明
选项列表:
选项名称1|选项值1(回车换行)
②、调用方法
{$字段名称}
4、编辑器(editor)
①、参数说明
宽度:
编辑器的width值,以百分比为单位
高度:
编辑器的height值,以px为单位
类型:
两种模式而已
②、调用方法
{$字段名称}
5、单选按钮(radio)
①、参数说明
选项列表:
选项名称1|选项值1(回车换行)
②、调用方法
{$字段名称}
6、复选框(checkbox)
①、参数说明
选项列表:
选项名称1|选项值1(回车换行)
②、调用方法
返回数组格式的$value,$value是选中的值,可以用loop循环操作它
7、单图上传(image)
①、参数说明
jpg、gif、png格式图片,不得超过2MB
②、调用方法
{thumb($字段名称)}
8、文件上传(file)
①、参数说明
限制格式:
多个格式以,号分开,如:
zip,rar,tar
文件大小:
单个文件的大小限制,以MB为单位
②、调用方法
{getfile($字段名称)}
9、多文件上传(files)
①、参数说明
限制格式:
多个格式以,号分开,如:
zip,rar,tar,jpg,png
文件大小:
单个文件的大小限制,以MB为单位
②、调用方法
文件地址的数组:
$value['file'],
文件名称的数组:
$value['alt']
循环示例如下:
{loop$value['file']$k=>$file}
文件地址:
{getfile($file)}
文件名称:
{$value['alt'][$k]}
{/loop}
10、日期时间(date)
①、参数说明
显示格式:
与PHP的date函数格式一致
②、调用方法
{$字段名称}
11、联动菜单(linkage)
①、参数说明
绑定菜单:
选择已经建好的联动菜单
联动级别:
就是这个菜单有多少级
②、调用方法
{php$data=linkagelist(联动菜单keyid,菜单id);}
{loop$data$t}
名称:
{$t['name']}
id号:
{$t['id']}
子菜单集合:
{$t['arrchilds']}(若无子菜单,该值为空).
如果该菜单有子菜单就循环调用linkagelist(联动菜单keyid,子菜单id),依次循环
{/loop}
更多联动菜单功能介绍请参考系统默认模板中的房产模型及联动菜单相关函数介绍
12、地图字段(map)
①、参数说明
XXKEY:
到XX去申请
默认城市:
可填写中文,如“北京”
②、调用方法
{baiduMap(模型id,HTMLdiv的id,$字段,宽,高)}
13、组合字段(merge)
这个最简单,不用多介绍,例子很清楚
{字段名称}[介绍],例如:
{shi}室,{ting}厅,{wei}卫
14、多字段组合(fields)
“多字段组合”要区别于“组合字段”
可以把“多字段组合”看成一个独立字段,而“组合字段”是由多个独立字段组成
按照公交线路举例:
建立一个“公交线路”字段,类型为“多字段组合”字段,由“线路”,“车时”,“价钱”等字段组合,用户可以添加多组“公交线路”
“多字段组合”可以自由删除,排序选项,实现多栏展示数据
调用方式为:
{loop$value$t}//循环多字段
值:
{$t[字段]}
{/loop}
二、自定义字段表单调用
{listaction=fieldmodelid=$modelidname=字段名称value=字段默认值}...{/list}
modelid:
栏模型id(必选)
name:
字段名称(必选)
value:
字段值(可选)
返回数据{$t['form']}:
用于表单显示(就是一个表单输入框)
返回数据{$t['data']}:
返回复选框、单选按钮中的选项名称和值(数组类型,若要输出请用loop配合)
例:
①、调用模型2中的自定义字段zhiduan(默认值200)的输入表单
{listaction=fieldmodelid=2name=zhiduanvalue=200}{$t['form']}{/list}
②、调用模型2中的自定义字段zhiduan(必须是复选框、单选按钮类型)的值
{listaction=fieldmodelid=2name=zhiduan}
{loop$t['data']$n=>$v}
名称:
{$n},值:
{$v};
{/loop}
{/list}
因为$t['data']是数组类型,说以要用loop循环输出,不用解释太多大家都懂
(一十四)[静态/伪静态]自定义URL地址详细教程
一、如何开启自定义URL
进入后台,“内容管理”-“栏目管理”,选择修改或者添加栏目,“URL配置”,开启“自定义URL规则”,再配置适合自己的规则。
二、规则标签说明
{dir}:
表示栏目目录
{pdir}:
表示包含父级层次的栏目目录(不能与{dir}同时出现,两者二选一)
{page}:
表示分页id
{id}:
表示内容或栏目的id
{y}:
表示年(内容规则中有效)
{m}:
表示月(内容规则中有效)
{d}:
表示日(内容规则中有效)
三、举例说明
在添加/修改栏目时候,会发现一个选项“URL设置”。
问题来了,你点这些地址,会不会发现会出现“404”错误或者是指向首页,这是为什么呢?
解决方案有2种。
方案1、生成静态页面
注意:
如果内容URL没有变化的话请“更新内容地址”
方案2、设置伪静态
①、指向地址说明
栏目列表指向地址:
index.php?
c=content&a=list&catdir=栏目目录或者index.php?
c=content&a=list&catid=栏目ID
栏目分页指向地址:
index.php?
c=content&a=list&catdir=栏目目录&page=分页或者index.php?
c=content&a=list&catid=栏目ID&page=分页
内容页面指向地址:
index.php?
c=content&a=show&id=文章id
内容分页指向地址:
index.php?
c=content&a=show&id=文章id&page=分页
②news是栏目目录news是栏目目录,1是分页id1是文章的id前者1是文章的id,后者1是分页id)
伪静态方案一:
修改服务器伪静态配置文件
以apache为例,修改.htaccess文件:
RewriteEngineOn
RewriteCond%{REQUEST_FILENAME}!
-f
RewriteCond%{REQUEST_FILENAME}!
-d
RewriteRule^list-([a-z0-9A-Z]+).html$index.php?
c=content&a=list&catdir=$1[L]
RewriteRule^list-([a-z0-9A-Z]+)-([0-9]+).html$index.php?
c=content&a=list&catdir=$1&page=$2[L]
RewriteRule^show-([0-9]+).html$index.php?
c=content&a=show&id=$1[L]
RewriteRule^show-([0-9]+)-([0-9]+).html$index.php?
c=content&a=show&id=$1&page=$2[L]
以iis为例,修改httpd.ini文件:
[ISAPI_Rewrite]
CacheClockRate3600
RepeatLimit32
RewriteRule^(.*)/list-([a-z0-9A-Z]+)\.html$$1/index.php?
c=content&a=list&catdir=$2[L]
RewriteRule^(.*)/list-([a-z0-9A-Z]+)-([0-9]+)\.html$$1/index.php?
c=content&a=list&catdir=$2&page=$3[L]
RewriteRule^(.*)/show-([0-9]+)\.html$$1/index.php?
c=content&a=show&id=$2[L]
RewriteRule^(.*)/show-([0-9]+)-([0-9]+)\.html$$1/index.php?
c=content&a=show&id=$2&page=$3[L]
以Nginx为例:
rewrite^([^\.]*)/list-([a-z0-9A-Z]+)\.html$$1/index.php?
c=content&a=list&catdir=$2last;
rewrite^([^\.]*)/list-([a-z0-9A-Z]+)-([0-9]+)\.html$$1/index.php?
c=content&a=list&catdir=$2&page=$3last;
rewrite^([^\.]*)/show-([0-9]+)\.html$$1/index.php?
c=content&a=show&id=$2last;
rewrite^([^\.]*)/show-([0-9]+)-([0-9]+)\.html$$1/index.php?
c=content&a=show&id=$2&page=$3last;
当然这种方案的前提需要服务器开启伪静态并指向index.php,再次说一下方法,goooooo。
以apache为例,修改.htaccess文件:
RewriteEngineOn
RewriteCond%{REQUEST_FILENAME}!
-f
RewriteCond%{REQUEST_FILENAME}!
-d
RewriteRule!
\.(js|ico|gif|jpg|png|css|swf)$index.php[L]
然后根据上面你自定义的路由格式来设计伪静态指向(一定要懂正则表达式一定注意不能用记事本之类的工具修改)
规则格式图:
按照上面的例子,我们可以设计成如下匹配规则:
熟悉正则表达式的朋友应该一眼能看懂,再次强调使用该方法一定要懂正则表达式哦~~
注意:
伪静态方案二的指向地址不需要再加index.php了
(一十五)生成静态教程
方案1、生成静态页面
注意:
如果内容URL没有变化的话请“更新内容地址”
方案2、设置伪静态
①、指向地址说明
栏目列表指向地址:
index.php?
c=content&a=list&catdir=栏目目录或者index.php?
c=content&a=list&catid=栏目ID
栏目分页指向地址:
index.php?
c=content&a=list&catdir=栏目目录&page=分页或者index.php?
c=content&a=list&catid=栏目ID&page=分页
内容页面指向地址:
index.php?
c=content&a=show&id=文章id
内容分页指向地址:
index.php?
c=content&a=show&id=文章id&page=分页
②news是栏目目录news是栏目目录,1是分页id1是文章的id前者1是文章的id,后者1是分页id)
伪静态方案一:
修改服务器伪静态配置文件
以apache为例,修改.htaccess文件:
RewriteEngineOn
RewriteCond%{REQUEST_FILENAME}!
-f
RewriteCond%{REQUEST_FILENAME}!
-d
RewriteRule^list-([a-z0-9A-Z]+).html$index.php?
c=content&a=list&catdir=$1[L]
RewriteRule^list-([a-z0-9A-Z]+)-([0-9]+).html$index.php?
c=content&a=list&catdir=$1&page=$2[L]
RewriteRule^show-([0-9]+).html$index.php?
c=content&a=show&id=$1[L]
RewriteRule^show-([0-9]+)-([0-9]+).html$index.php?
c=content&a=show&id=$1&page=$2[L]
以iis为例,修改httpd.ini文件:
[ISAPI_Rewrite]
CacheClockRate3600
RepeatLimit32
RewriteRule^(.*)/list-([a-z0-9A
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- FineCMS 使用手册