cms 后台管理系统

时间: 2023-12-28 18:25:59 浏览: 251
CMS后台管理系统是一种用于管理网站内容的系统。它提供了一个用户友好的界面,使网站管理员能够轻松地创建、编辑和发布内容,而无需编写代码或了解复杂的技术知识。CMS后台管理系统通常包括以下功能: 1. 内容编辑:管理员可以使用富文本编辑器创建和编辑网站内容,包括文章、页面、图片和视频等。 2. 内容发布:管理员可以将编辑好的内容发布到网站上,使其对访问者可见。 3. 用户管理:管理员可以管理网站的用户,包括创建用户账号、分配权限和管理用户角色等。 4. 界面定制:管理员可以根据需要自定义网站的外观和布局,包括选择主题、调整颜色和字体等。 5. SEO优化:CMS后台管理系统通常提供一些SEO工具,帮助管理员优化网站内容,提高搜索引擎排名。 6. 数据统计:管理员可以查看网站的访问量、用户行为和其他相关数据,以便进行分析和优化。 7. 扩展性:一些CMS后台管理系统支持插件和扩展,使管理员能够根据需要添加新的功能和模块。 总之,CMS后台管理系统是一个强大的工具,使网站管理员能够轻松管理和维护网站内容,提高工作效率并改善用户体验。
阅读全文

相关推荐

rar
一 Jeecms安装过程 将解压后得到的jeecms-3.0.2-final文件夹下的root文件夹更名为jeecms拷贝到tomcat 安装目录下的webapps 文件夹下(例如: D:\Tomcat 6.0\webapps\),启动tomcat,在地址栏中输入http://localhost:8080/jeecms, 您将看到第一步安装过程中的《用户许可协议》,勾选“我已经阅读并同意此 协议”,点击下一步, 接下来第二步安装过程中设置系统参数,系统会自动检测出一些配置项,请根据您的实际情 况填写,数据库密码不能为空。 点击提交后进入第三步进入最后的系统安装过程,安装过程可能需要十几秒的等待时间。安 装成功后将提示信息,请再重启Tomcat 完成安装。 Tomcat重启完毕之后,在浏览器的地址栏中输入http://localhost:8080/jeecms, 若系统正常显示默认的站点首页则表示JEECMS 已经顺利安装完成. 附: 系统管理后台登录:http://localhost:8080/jeecms/jeeadmin/jeecms/index.do 用户名:admin 密 码:password 图文安装步骤如下: 将解压后得到的ROOT文件夹拷贝到tomcat安装目录下的webapps文件夹下(例如:D:\Tomcat 6.0\webapps\),启动tomcat,在地址栏中输入http://localhost:8080,您将看到第一步安装过程中的《用户许可协议》,如图一所示,勾选“我已经阅读并同意此协议”,点击下一步, 图一:用户许可协议 接下来第二步安装过程中设置系统参数,系统会自动检测出一些配置项,请根据您的实际情况填写,如图二所示,数据库密码不能为空。 图二:系统参数设置 点击提交后进入第三步进入最后的系统安装过程,安装过程可能需要十几秒的等待时间。安装成功后将提示如图三所示的页面信息,请再重启Tomcat完成安装。 图三:系统安装完成 三、完成安装 Tomcat重启完毕之后,在浏览器的地址栏中输入http://localhost:8080,若系统正常显示默认的站点首页则表示JEECMS已经顺利安装完成.,如图四所示: 图四 站点首页 二 Jeecms项目导入myeclipse 1.在myeclipse中新建一个项目jeecms,将服务器中jeecms项目下web-inf文件夹下内容拷到新建项目中 解压缩jeecms-3.0.2-final-src,在src文件夹下会看到有三个压缩文件,如果只想进行普通的二次开发,可以只导入cms这个源码,删除jeecms-cms-identity-3.0.2-final.jar即可,如果想进行深入的二次开发,需要导入common和core源码,另导入common-lib下的jar包,删除jeecms-cms- identity-3.0.2-final.jar,jeecms-common-3.0.2-final.jar ,jeecms-core- identity-3.0.2-final.jar这三个jar包,切记:务必进行build path 3.修改jdbc链接,自己导入数据库。 4.把服务器下install\config下的web.xml复制出来覆盖掉新建项目WEB-INF下的web.xml 5.classes下有四个文件,手动烤到myeclipse项目src根目录下中 6.将服务器上jeecms项目删掉,发布新建的jeecms项目。 三 首页的加载过程 在浏览器中输入http://localhost:8080/jeecms,回车 首先进入配置文件web.xml, <context-param> contextConfigLocation <!----> /WEB-INF/config/application-context.xml /WEB-INF/config/cache-context.xml /WEB-INF/config/captcha-context.xml /WEB-INF/config/jeecore-context.xml /WEB-INF/config/jeecms-context.xml </context-param> 应用范围内的初始化参数 其中jeecms-context.xml是对标签的初始化 <welcome-file-list> <welcome-file>index.html</welcome-file> <welcome-file>index.shtml</welcome-file> <welcome-file>index.jhtml</welcome-file> </welcome-file-list> 通过以上标签找到应该加载哪一个页面 <servlet> <servlet-name>JeeCmsFront</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> contextConfigLocation /WEB-INF/config/jeecms-servlet-front.xml </init-param> <load-on-startup>2</load-on-startup> </servlet> <servlet-mapping> <servlet-name>JeeCmsFront</servlet-name> <url-pattern>*.jhtml</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>JeeCmsFront</servlet-name> <url-pattern>*.jspx</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>JeeCmsFront</servlet-name> <url-pattern>*.jsp</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>JeeCmsFront</servlet-name> <url-pattern>*.htm</url-pattern> </servlet-mapping> 通过servlet配置,可以找到jeecms-servlet-front.xml,在此配置文件的最后有 <import resource="jeecms-servlet-front-action.xml"/>代码 找到jeecms-servlet-front-action.xml,在此配置文件中有 <bean id="dynamicAct" class="com.jeecms.cms.action.front.DynamicPageAct"/> 可以找到类DynamicPageAct,此类是首页模板。 在类DynamicPageAct中有 public static final String TPL_INDEX = "tpl.index"; 找到WEB-INF\languages\jeecms_front下messages_zh_CN.properties配置文件,可以找到对应的首页面 tpl.index=首页(工程中的首页.html文件) 四 标签的配置流程 以cms_content_list为例,首先,每一个标签的声明都是在jeecms-context.xml中进行的, <?xml version="1.0" encoding="UTF-8"?> <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd" default-lazy-init="true"> …… <bean id="cms_content_list" class="com.jeecms.cms.action.directive.ContentListDirective"/>(声明标签对应的类) <bean id="staticPageSvc" class="com.jeecms.cms.staticpage.StaticPageSvcImpl"> <bean class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <map> …… <entry key="cms_content_list" value-ref="cms_content_list"/> …… </map> …… </bean> </bean> </beans> 此外,在配置文件jeecms-servlet-front.xml中,还有一段对标签的配置 <bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer"> <map> …… <entry key="cms_content_list" value-ref="cms_content_list"/> …… </map> …… </bean> </bean> 类ContentListDirective继承自AbstractContentDirective,最主要的是execute方法 public class ContentListDirective extends AbstractContentDirective { /** * 模板名称 */ public static final String TPL_NAME = "content_list"; /** * 输入参数,文章ID。允许多个文章ID,用","分开。排斥其他所有筛选参数。 */ public static final String PARAM_IDS = "ids"; @SuppressWarnings("unchecked") public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { //获取站点 CmsSite site = FrontUtils.getSite(env); //获取内容列表,可以通过此处进行更改,获取自己数据库中的数据 List<Content> list = getList(params, env); Map<String, TemplateModel> paramWrap = new HashMap<String, TemplateModel>( params); //OUT_LIST值为tag_list,在类DirectiveUtils中声明,将内容列表放入其中 paramWrap.put(OUT_LIST, DEFAULT_WRAPPER.wrap(list)); //将params的值复制到variable中 Map<String, TemplateModel> origMap = DirectiveUtils .addParamsToVariable(env, paramWrap); //获取的是参数PARAM_TPL,是否调用模板以及调用的模板类型 InvokeType type = DirectiveUtils.getInvokeType(params); //获取传入参数,列表样式,根据不同的参数获取不同的样式列表 String listStyle = DirectiveUtils.getString(PARAM_STYLE_LIST, params); if (InvokeType.sysDefined == type) { if (StringUtils.isBlank(listStyle)) { throw new ParamsRequiredException(PARAM_STYLE_LIST); } //列表样式模板 env.include(TPL_STYLE_LIST + listStyle + TPL_SUFFIX, UTF8, true); } else if (InvokeType.userDefined == type) { if (StringUtils.isBlank(listStyle)) { throw new ParamsRequiredException(PARAM_STYLE_LIST); } //列表样式模板路径 WEB-INF\t\cms_sys_defined\style_list\style_2-1.html FrontUtils.includeTpl(TPL_STYLE_LIST, site, env); } else if (InvokeType.custom == type) { //这个模板就是自己声明的,即content_list.html,如果采用自定义模板的话,页面中可以只写上标签,并添加上标签内需要的几个参数,不需要写标签体的内容,会去自动调用模板中的标签体。 FrontUtils.includeTpl(TPL_NAME, site, params, env); } else if (InvokeType.body == type) { body.render(env.getOut()); } else { throw new RuntimeException("invoke type not handled: " + type); } //将variable中的params值移除 DirectiveUtils.removeParamsFromVariable(env, paramWrap, origMap); } @SuppressWarnings("unchecked") protected List<Content> getList(Map<String, TemplateModel> params, Environment env) throws TemplateException { Integer[] ids = DirectiveUtils.getIntArray(PARAM_IDS, params); if (ids != null) { //根据内容ID数组获取文章列表 return contentMng.getListByIdsForTag(ids, getOrderBy(params)); } else { return (List<Content>) super.getData(params, env); } } @Override protected boolean isPage() { return false; } } Content_list.html中的内容 [#list tag_list as a] ${a.title} [/#list] 就是简单的将tag_list中的内容,即“paramWrap.put(OUT_LIST, DEFAULT_WRAPPER.wrap(list));”中放入的数据遍历出来 style_2-1.html中的内容 主要是对图文列表或标题列表向上滚动的样式的,其中包含两个同样为样式的文件 style_2-1_core.html(图文列表或标题列表向上滚动)和style_1-1_core.html(图文列表或标题列表向上滚动),在此就不做赘述了。 Jeecms是基于Spring注解,在自定义标签时对于实体类和dao service等注意注解的问题。 五 自定义标签及使用自己创建的表的实现过程 下面是我自己定义的标签mycontent_list 首先,在数据库里创建了一个jc_mycontent的表,其中有id,title,content三个字段 其次,创建了一个实体类 public class MyContent { private static final long serialVersionUID = 1L; private Integer id; private String title; private String content; public MyContent () { super(); } ……get set方法 } 接下来是配置hibernate中jc_mycontent表的配置文件 <?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.jeecms.cms.entity.main"> <class name="MyContent" table="jc_mycontent"> <meta attribute="sync-DAO">false</meta> <cache usage="read-write"/> <id name="id" type="java.lang.Integer" column="id"><generator class="identity"/></id> </class> </hibernate-mapping> 与数据库交互的持久层接口 public interface MyContentDao { public List<MyContent> getList(); } 持久层实现类 @Repository//持久层 public class MyContentDaoImpl extends HibernateBaseDao<MyContent, Integer> implements MyContentDao { @SuppressWarnings("unchecked") public List<MyContent> getList(){ return find(byNothing()); } private Finder byNothing(){ Finder f = Finder.create(); f.append("from MyContent");//可以在此处添加查询条件或者添加各种方法进行动态查询 f.setCacheable(true); return f; } @Override protected Class<MyContent> getEntityClass() { return MyContent.class; } } 业务层接口 public interface MyContentMng { public List<MyContent> getList(); } 业务层实现类 @Service//业务层 @Transactional public class MyContentMngImpl implements MyContentMng { @Transactional(readOnly = true)//配置事务为只读 public List<MyContent> getList(){ return myContentDao.getList(); } private MyContentDao myContentDao; @Autowired//自动绑定 public void setMyContentDao(MyContentDao myContentDao) { this.myContentDao = myContentDao; } private List<ContentListener> listenerList; @Autowired public void setListenerList(List<ContentListener> listenerList) { this.listenerList = listenerList; } } 标签类的抽象类,最主要的就是getData这个方法,以及绑定业务层,其中可以添加多种查询方法。可参考类AbstractContentDirective public abstract class AbstractMyContentDirective implements TemplateDirectiveModel { protected Object getData(Map<String, TemplateModel> params, Environment env) throws TemplateException { return myContentMng.getList(); } @Autowired protected MyContentMng myContentMng; } 自定义标签中最重要的类继承上边的抽象类 public class MyContentListDirective extends AbstractMyContentDirective { /** * 模板名称 */ public static final String TPL_NAME = "mycontent_list"; @SuppressWarnings("unchecked") public void execute(Environment env, Map params, TemplateModel[] loopVars, TemplateDirectiveBody body) throws TemplateException, IOException { //获取站点 CmsSite site = FrontUtils.getSite(env); //获取内容列表 List<MyContent> list = getList(params, env); Map<String, TemplateModel> paramWrap = new HashMap<String, TemplateModel>(params); //OUT_LIST值为tag_list,将内容列表放入其中 paramWrap.put(MYOUT_LIST, DEFAULT_WRAPPER.wrap(list)); //将params的值复制到variable中 Map<String, TemplateModel> origMap = DirectiveUtils.addParamsToVariable(env, paramWrap); //没有采用默认的模板,直接采用自己写的简单的模板(mycontent_list.html) FrontUtils.includeTpl(TPL_NAME, site, params, env); //将variable中的params值移除 DirectiveUtils.removeParamsFromVariable(env, paramWrap, origMap); } protected List<MyContent> getList(Map<String, TemplateModel> params, Environment env) throws TemplateException { return myContentMng.getList(); } } 样式模板mycontent_list.html内容,里边可以自己添加一些样式,可参考\t\cms_sys_defined\style_list下样式文件 [#list mytag_list as a] "${a.content}" [/#list] 首页里加入如下代码 [@cms_mycontent_list] [/@cms_mycontent_list] 通过以上这些代码,可以实现将自己的表jc_mycontent中的数据查询并显示在页面上 六 标签使用和模板的制作 1模板规划 1.1资源文件 资源文件就是网页中用到的图片、CSS、JS等元素,在CMS系统中所有的资源文件在网站的根目录中的 /res_base/所属网站定义资源目录/TEMPLEATE/WEB /res_base/所属网站定义资源目录/TEMPLEATE/WAP 解释:网站定义资源 在CMS系统中可以同时管理多个网站,也就是多个网站可以同时使用一套CMS系统,但是每一个网站都已属于自己独立的资源文件及模板文件目录。 1.2模板文件 定义了页面显示的主体框架,它的位置位于网站根目录下的/WEB_INF/user_base/所属网站模板目录; 模板规则: 1、以index前缀命名的为首页模板 2、以channel前缀命名的为栏目模板 3、以content前缀命名的为内容模板 4、以alone前缀命名的为栏目单页模板 1.3使用方式 1、使用dw建立站点 2、将网页中用到的资源文件分类分别放置到网站相关资源目录中 3、将模板文件放置按照命名规则分别放置到网站相关模板目录中。 4、将头部、底部等等具有通用元素的模板文件放置到模板目录中的include目录中 5、将模板文件中所有资源引用改为绝对路径链接至资源目录中 6、在栏目管理中将模板文件与栏目进行关联设置 7、在模板文件中需要提取数据的位置放置相应的标签 1.4标签调用样式 调用"JEECMS标签"的三种代码样式如下:   A、${标签名称}   B、[@cms.标签名称 属性='值'/]   C、[@cms.标签名称 属性='值'; 标签别名] 自定义样式模板 [/@cms.标签名称]   例如: a、${web.name}标签用于调用网站名称 b、[@cms.ArtiList chnlId='' count='10' sysContent='1-1' /]标签用于调用 10篇文章的列表 C、[@cms.ChnlList id='' inner='1';c]|>${c.name} [/@cms.ChnlList]标签用于调用栏目列表,可用于网站导航条。   注意:abc实例是与上面ABC三种形式相对应的。大家可以逐个测试,举一反三 2 Include标签 2.1功能简介 做过网站设计经验的朋友可能都知道,我们可以将页面中经常要引用的公共部分(比如页头和页脚)独立开来,单独存放在一个页面中。这样做的好处就是可以在各个需要用到该部分的页面中用一个简单的包含语句就能把它引入进来,大大简化了工作量。 2.2标记说明 【标签名】:[@cms.Include 属性='值' /] 【作 用】:包含公用页面(如页头,页脚) 【参 数】: name:包含模板的文件名 solution:模板方案名 【示 例】: 包含页头:[@cms.Include name='head.html' solution='default'/] 【备 注】:调用此标签前必须先建立相应的包含模板 2.3 明确标签的使用范围   我们在使用任何标签的之前,都必须明确其使用的范围,否则可能无法正常使用该标签。   【Include 标签】的使用范围是:首页模板,栏目页模板,内容页模板,即对应\WEB-INF\user_base\jeecms_com_www\template\article\default\文件夹下的index_××.html模板、channel_××.html模板、content_××.html模板 2.4调试标签了解其使用方法   在使用【Include 标签】之前我们必须保证有可供此标签调用的包含模板,本实例只是起演示作用,为方便起见,这里就不再另外创建被包含的模板了,标签调用的是系统默认模板方案中的的head.html模板。 登录JEECMS后台,进入“模板管理->template->article->default”,点击修改开始时建立的index_demo.html模板(如果没有此模板则按照本文开头的说明创建),进入模板代码模式,填写如下标签代码(为了演示效果美观,本处代码中加入了css,可去除): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>Include标签测试</title> <link href="${sysResRoot}/front.css" type="text/css" rel="stylesheet" /> <link href="${root}/default/article/css/whole.css" type="text/css" rel="stylesheet" /> <link href="${root}/default/article/css/layout.css" type="text/css" rel="stylesheet" /> </head> <body> [@cms.Include name='head.html' solution='default'/] </body> </html>   点保存按钮,然后返回前台站点首页刷新,得到如下效果: 3 ArtiList标签 3.1功能简介 【ArtiList 标签】在CMS中使用的频率可以说是最高的,通过这个标签,你不仅可以得到一个文章列表,而且可以通过不同的参数组合得到不同的显示效果。比如文章图文列表、文字或图片跑马灯、文字或图片上下循环滚动等等。 使用方式: [@cms.ArtiList chnlId='' count='5' sysContent='1-1' titLen='25' lineHeight='1' dateFormat='4' datePosition='2' headMark='2' target='1'/] 3.2标记说明 【标签名】:[@cms. ArtiList 属性='值' /] 【作 用】:获取文章列表数据 【参 数】: 属性名称 属性说明 默认值 可选值 chnlId 栏目ID,栏目页中可不设置,系统会自动获取当前栏目ID 当前栏目ID 空:显示全站文章列表; 栏目ID:指定栏目文章 attr 文章属性ID 空 1:普通 2:图文 3:焦点 4:头条 5:滚动 sysContent 列表显示方式 1-1 1-1:普通标题列表 1-2:图文列表 2-1:标题列表翻滚 2-2:图文列表翻滚 3-1:焦点图 orderBy 排序方式 0 0:发布时间降序; 1:发布时间升序; 2:固顶降序; 3:置顶降序; 4:日点击降序; 5:周点击降序; 6:月点击降序; 7:季点击降序; 8:年点击降序; 9:总点击降序 recommend 是否推荐 0 0:所有文章 1:推荐文章 titLen 标题长度 20 自定义 target 链接打开目标 0 0:原窗口打开 1:新窗口打开 headMark 文章标题图标 0 0:无图标 1:黑色小圆点 2:红色小圆点 3:蓝色单箭头 4:蓝色双箭头 自定义图标:填写图标路 lineHeight 文章列表每行的行高 空 自定义 bottomLine 每行标题下是否带下划分隔线 0 0:无分隔线 1:默认分隔线 自定义样式:css中定义的样式名称 ctgForm 文章类别形式 0 0:不显示文章类别 1:显示栏目类别 2:显示站点名称 ctgClass 文章类别的css-class 空 自定义css样式的class名 dateFormat 文章发布日期显示格式 0 0:不显示日期 1:”年-月-日 时-分-秒” 格式 2:”年-月-日” 格式 3:”月-日 时-分” 格式 4:”月-日” 格式 datePosition 日期排列位置 1 1:紧跟标题之后 2:右对齐 3:左对齐 isPage 是否显示分页 0 0:否;1:是 count 每页列表显示数量 20 自定义 cssStyle 连接的样式 空 自定义 仅当sysContent='1-2'(图文列表)时,以下标签属性才有效 picWidth 按百分比显示图片宽度 25(即每个图片占总宽度的25%,每行可放四张图片) 自定义 picHeight 每行图片显示高度 110 自定义 仅当sysContent='3-×'(焦点图)时,以下标签属性才有效 flashWidth 焦点图宽度 296(px) 自定义 flashHeight 焦点图总高度 200(px) 自定义 textHeight 焦点图文本高度 20(px) 自定义 仅当sysContent='2-×'(特效显示)时,以下标签属性才有效 rollDisplayHeight 显示区高度 28 自定义 rollLineHeight 行高 28 自定义 rollCols 列数(一行中包含几列) 1 自定义 rollSpeed 滚动速度,值越小越快,最小为1 1 自定义 isSleep 是否停顿 1 0:不停顿; 1:停顿 rollSleepTime 停顿时间,值越大停顿越久 50 自定义 rollCount 一次滚动的行数 1 自定义 rollSpan 一次滚动的像素 1 自定义 其它高级标签属性(用于用户个性设置) searchKey 在标题、tags和描述中搜索指定关键字的文章列表,用于搜索页模板 空 自定义关键字 style 标签内部样式,如果指定sysContent或userContent,则该项无效 1 1:普通列表 sysTpl 指定系统模板 1 自定义 sysContent 系统内容样式 0 自定义 userContent 用户内容样式,当sysContent=1时有效 空 自定义 sysPage 系统分页样式 0 自定义 userPage 用户分页样式,当sysPage=1时有效 空 自定义 upSolution 指定其它模板方案样式 空 自定义 upWebRes 指定其它站点样式 空 自定义 pageClass 分页栏css样式的class名称 空 自定义 pageStyle 分页栏css自定义style样式 空 自定义 3.3 明确标签使用范围   我们在使用任何标签的之前,都必须明确其使用的范围,否则可能无法正常使用该标签。 【ArtiList 标签】的使用范围是:首页模板,栏目页模板,内容页模板, 即对应\WEB-INF\user_base\jeecms_com_www\template\article\default\文件夹下的index_××.html模板、channel_××.html模板、content_××.html模板 3.4 调试标签了解其使用方法   登录JEECMS后台,进入“模板管理->template->article->default”,点击修改开始时建立的index_demo.html模板(如果没有此模板则按照本文开头的说明创建),在模板内容处填写如下标签代码(为了演示效果美观,本处代码中引入了系统默认css,可去除):(1).文章列表 <link href="${sysResRoot}/front.css" type="text/css" rel="stylesheet" /> [@cms.ArtiList chnlId='' count='5' sysContent='1-1' titLen='25' lineHeight='1' dateFormat='4' datePosition='2' headMark='2 target='1'/]  点保存按钮,然后返回前台站点首页刷新,得到如下效果: (2).图文列表 <link href="${sysResRoot}/front.css" type="text/css" rel="stylesheet/> [@cms.ArtiList chnlId='' attr='2' count='5' sysContent='1-2' titLen='25' target='1' picWidth='25' picHeight='110'/]   点保存按钮,然后返回前台站点首页刷新,得到如下效果: 4 Position标签 4.1功能简介 在网站页面中我们经常要显示当前页面的位置,例如:当前位置:首页 > 无线城市> 城市要闻 > 正文。在CMS标签中提供了一个显示页面的当前位置调用标签,只需将该标签放到页面的相应地方,设置好调用参数即可,简单方便。 4.2标记说明 【标签名】:[@cms.Position 属性='值' /] 【作 用】:显示页面的当前位置  【参 数】:   homepage —-首页显示方式。【1:站点简称;自定义】(默认:首页)   title ---内容页显示方式。【0:不显示;1:显示内容标题;自定义】(默认:正文)   split ---分割符号。(默认:“>”)   target ---是否原窗口打开。【0:原窗口打开;1:新窗口打开】(默认:原窗口打开)   class ---链接外部样式,等同于html中的class属性   style ---自定义标签样式,等同于html中的style属性  【示 例】:   [@cms.Position homepage='1' split='|' target='1' /] 【作 用】:显示各栏目列表 【参 数】: 属性名称 属性说明 默认值 可选值 id 父栏目ID 默认为空:自动获取当前栏目ID 空:当前栏目ID; 栏目ID:指定父栏目id orderBy 排序方式 0 0:优先级升序; 1:优先级降序; 2:点击次数升序;3:点击次数降序 isDisplay 是否只获取显示的栏目 1 0:获取所有; 1:只获取显示的栏目 hasContent 是否只获取可以有内容的栏目 0 0:获取所有; 1:只获取可以有内容的栏目 linkClass 链接class样式 空 linkTarget 链接打开方式 0 0:当前窗口; 1:新窗口 sysPage 系统分页样式 0 0:不分页; 1:样式一; 2:样式二 userPage 自定义分页样式。如果指定了系统分页样式,则该项无效 0 0:不分页; 1:样式一; 2:样式二 5.3明确标签的使用范围   我们在使用任何标签的之前,都必须明确其使用的范围,否则可能无法正常使用该标签。 [@cms.ChnlList /]标签的使用范围是:首页模板,栏目页模板,即对应\\WEB-INF\\user_base\\jeecms_com_www\\template\\article\\default\\文件夹下的index_××.html模板、channel_××.html模板 5.4调试标签了解其使用方法 1、单独标签调用示例: [@cms.ChnlList/] 2、自定义标签调用示例:    [@cms.ChnlList id='' inner='1';c,i]     <a href="${c.url}">${c.name}[#if (i+1)%2==0]
[/#if]    [/@cms.ChnlList] 3、配合其它标签嵌套调用示例: [@cms.ChnlList id='' sysType='article' hasContent='1' inner='1';c] ${c.name} [@cms.ArtiList chnlId=c.id sysContent='1-1' titLen='20' count='6' /] [/@cms.ChnlList] 6内容页常用标签 6.1标记说明 【文章导航】:[@cms.Position /] 【文章标题】:${arti.title} 【简短标题】:${arti.shortTitle} 【文章作者】:${arti.author} 【发布日期】:${arti.releaseDate} 【查看次数】:${arti.visitTotal} 【文章来源】:${arti.origin} 【文章摘要】:${arti.description} 【文章内容】:${arti.content}

大家在看

recommend-type

GD32F系列分散加载说明

GD32官网提供的GD32F系列分散加载应用笔记
recommend-type

建立点击按钮-INTOUCH资料

建立点击按钮 如果需要创建用鼠标单击或触摸(当使用触摸屏时)时可立即执行操作的对象链接,您可以使用“触动按钮触动链接”。这些操作可以是改变离散值离散值离散值离散值、执行动作脚本动作脚本动作脚本动作脚本,显示窗口或隐藏窗口命令。下面是四种触动按钮链接类型: 触动按钮 描述 离散值 用于将任何对象或符号设置成用于控制离散标记名状态的按钮。按钮动作可以是设置、重置、切换、瞬间打开(直接)和瞬间关闭(取反)类型。 动作 允许任何对象、符号或按钮链接最多三种不同的动作脚本:按下时、按下期间和释放时。动作脚本可用于将标记名设置为特定的值、显示和(或)隐藏窗口、启动和控制其它应用程序、执行函数等。 显示窗口 用于将对象或符号设置成单击或触摸时可打开一个或多个窗口的按钮。 隐藏窗口 用于将对象或符号设置成单击或触摸时可关闭一个或 多个窗口的按钮。
recommend-type

单片机与DSP中的基于DSP的PSK信号调制设计与实现

数字调制信号又称为键控信号, 其调制过程是用键控的方法由基带信号对载频信号的振幅、频率及相位进行调制。这种调制的最基本方法有三种: 振幅键控(ASK)、频移键控(FSK)、相移键控(PSK), 同时可根据所处理的基带信号的进制不同分为二进制和多进制调制(M进制)。多进制数字调制与二进制相比, 其频谱利用率更高。其中, QPSK (即4PSK) 是MPSK (多进制相移键控) 中应用较广泛的一种调制方式。为此, 本文研究了基于DSP的BPSK以及DPSK的调制电路的实现方法, 并给出了DSP调制实验的结果。   1 BPSK信号的调制实现   二进制相移键控(BPSK) 是多进制相移键控(M
recommend-type

菊安酱的机器学习第5期 支持向量机(直播).pdf

机器学习支持向量机,菊安酱的机器学习第5期
recommend-type

小米澎湃OS 钱包XPosed模块

小米EU澎湃OS系统 钱包XPosed模块,刷入后可以使用公交地铁门禁 支持MIUI14、澎湃OS1系统,基于小米12S 制作,理论适用于其他的型号。 使用教程: https://blog.csdn.net/qq_38202733/article/details/135017847

最新推荐

recommend-type

CMS内容管理系统.doc

内容管理系统(CMS)是一种专为管理和发布数字内容而设计的软件平台,它的出现是为了应对互联网信息爆炸带来的挑战,帮助企业或组织高效地管理、更新和维护网站内容。通过CMS,用户无需掌握复杂的编程语言,如SQL,...
recommend-type

74CMS 3.0 SQL注入漏洞后台.docx

74CMS 3.0 SQL 注入漏洞后台 本节将对 74CMS 3.0 SQL 注入漏洞后台进行详细分析,首先介绍了攻击环境的搭建,然后对代码进行了详细的审计,最后对漏洞进行了分析。 一、搭建攻击环境 为了进行攻击,我们需要搭建...
recommend-type

layui框架与SSM前后台交互的方法

四、layui框架介绍layui是一个轻量级的前端组件库,它提供了丰富的UI组件和便捷的API接口,适用于后台管理系统界面开发。layui的主要特性包括:1. 高度模块化:layui的每个功能都封装成独立的模块,方便按需加载和...
recommend-type

Wordpress中文CMS门户主题

在广告管理方面,Ssmay主题提供了多处广告位,如顶部、左栏中间、左栏下部以及侧边栏的上中下位置,用户可以在后台直接管理这些广告,轻松实现显示或隐藏,极大地满足了不同类型的广告需求。 此外,Ssmay主题引入了...
recommend-type

基于Andorid的音乐播放器项目改进版本设计.zip

基于Andorid的音乐播放器项目改进版本设计实现源码,主要针对计算机相关专业的正在做毕设的学生和需要项目实战练习的学习者,也可作为课程设计、期末大作业。
recommend-type

Windows下操作Linux图形界面的VNC工具

在信息技术领域,能够实现操作系统之间便捷的远程访问是非常重要的。尤其在实际工作中,当需要从Windows系统连接到远程的Linux服务器时,使用图形界面工具将极大地提高工作效率和便捷性。本文将详细介绍Windows连接Linux的图形界面工具的相关知识点。 首先,从标题可以看出,我们讨论的是一种能够让Windows用户通过图形界面访问Linux系统的方法。这里的图形界面工具是指能够让用户在Windows环境中,通过图形界面远程操控Linux服务器的软件。 描述部分重复强调了工具的用途,即在Windows平台上通过图形界面访问Linux系统的图形用户界面。这种方式使得用户无需直接操作Linux系统,即可完成管理任务。 标签部分提到了两个关键词:“Windows”和“连接”,以及“Linux的图形界面工具”,这进一步明确了我们讨论的是Windows环境下使用的远程连接Linux图形界面的工具。 在文件的名称列表中,我们看到了一个名为“vncview.exe”的文件。这是VNC Viewer的可执行文件,VNC(Virtual Network Computing)是一种远程显示系统,可以让用户通过网络控制另一台计算机的桌面。VNC Viewer是一个客户端软件,它允许用户连接到VNC服务器上,访问远程计算机的桌面环境。 VNC的工作原理如下: 1. 服务端设置:首先需要在Linux系统上安装并启动VNC服务器。VNC服务器监听特定端口,等待来自客户端的连接请求。在Linux系统上,常用的VNC服务器有VNC Server、Xvnc等。 2. 客户端连接:用户在Windows操作系统上使用VNC Viewer(如vncview.exe)来连接Linux系统上的VNC服务器。连接过程中,用户需要输入远程服务器的IP地址以及VNC服务器监听的端口号。 3. 认证过程:为了保证安全性,VNC在连接时可能会要求输入密码。密码是在Linux系统上设置VNC服务器时配置的,用于验证用户的身份。 4. 图形界面共享:一旦认证成功,VNC Viewer将显示远程Linux系统的桌面环境。用户可以通过VNC Viewer进行操作,如同操作本地计算机一样。 使用VNC连接Linux图形界面工具的好处包括: - 与Linux系统的图形用户界面进行交互,便于进行图形化操作。 - 方便的远程桌面管理,尤其适用于需要通过图形界面来安装软件、编辑配置文件、监控系统状态等场景。 - 跨平台操作,允许Windows用户在不离开他们熟悉的操作系统环境下访问Linux服务器。 除了VNC之外,还有一些其他的图形界面远程访问工具,例如: - RDP(Remote Desktop Protocol):通常与Windows远程桌面连接使用,但在Linux中也有相应的实现(如FreeRDP)。 - TeamViewer、AnyDesk等:这些工具提供了跨平台的远程桌面访问能力,虽然它们不是专为Linux设计,但它们都能很好地支持Linux系统。 在使用这些工具时,用户应该注意以下几点: - 安全性:确保使用强密码以及加密连接,防止未经授权的访问。 - 网络环境:需要保证网络的稳定性和带宽,以获得良好的远程桌面体验。 - 更新与维护:定期更新客户端和服务器端软件,确保安全性以及新功能的使用。 总结以上内容,Windows连接Linux图形界面的工具是实现跨平台远程管理的有效手段,特别是对于需要图形化操作的场景。VNC Viewer是一个应用广泛且成熟的工具,但选择适合自身需求的远程桌面工具对于提高工作效率与安全性至关重要。
recommend-type

【SketchUp Ruby API:从入门到精通】

# 摘要 本论文深入介绍了SketchUp Ruby API的使用与开发,为用户提供了一套从基础到进阶再到高级特性的完整学习路径。文章首先介绍了SketchUp Ruby API的基本概念、结构以及如何编写基础插件,并通过实例演示了3D模型的创建和编辑、用户界面定制等进阶应用。接着,探讨了高级特性,例如材质渲染、网络功能以及AP
recommend-type

VMware虚拟机打开虚拟网络编辑器出现由于找不到vnetlib.dll,无法继续执行代码。重新安装程序可能会解决问题

<think>好的,我需要帮助用户解决VMware虚拟机中缺少vnetlib.dll导致无法打开虚拟网络编辑器的问题。用户提到已经尝试过重新安装程序,但可能没有彻底卸载之前的残留文件。根据提供的引用资料,特别是引用[2]、[3]、[4]、[5],问题通常是由于VMware卸载不干净导致的。 首先,我应该列出彻底卸载VMware的步骤,包括关闭相关服务、使用卸载工具、清理注册表和文件残留,以及删除虚拟网卡。然后,建议重新安装最新版本的VMware。可能还需要提醒用户在安装后检查网络适配器设置,确保虚拟网卡正确安装。同时,用户可能需要手动恢复vnetlib.dll文件,但更安全的方法是通过官方安
recommend-type

基于Preact的高性能PWA实现定期天气信息更新

### 知识点详解 #### 1. React框架基础 React是由Facebook开发和维护的JavaScript库,专门用于构建用户界面。它是基于组件的,使得开发者能够创建大型的、动态的、数据驱动的Web应用。React的虚拟DOM(Virtual DOM)机制能够高效地更新和渲染界面,这是因为它仅对需要更新的部分进行操作,减少了与真实DOM的交互,从而提高了性能。 #### 2. Preact简介 Preact是一个与React功能相似的轻量级JavaScript库,它提供了React的核心功能,但体积更小,性能更高。Preact非常适合于需要快速加载和高效执行的场景,比如渐进式Web应用(Progressive Web Apps, PWA)。由于Preact的API与React非常接近,开发者可以在不牺牲太多现有React知识的情况下,享受到更轻量级的库带来的性能提升。 #### 3. 渐进式Web应用(PWA) PWA是一种设计理念,它通过一系列的Web技术使得Web应用能够提供类似原生应用的体验。PWA的特点包括离线能力、可安装性、即时加载、后台同步等。通过PWA,开发者能够为用户提供更快、更可靠、更互动的网页应用体验。PWA依赖于Service Workers、Manifest文件等技术来实现这些特性。 #### 4. Service Workers Service Workers是浏览器的一个额外的JavaScript线程,它可以拦截和处理网络请求,管理缓存,从而让Web应用可以离线工作。Service Workers运行在浏览器后台,不会影响Web页面的性能,为PWA的离线功能提供了技术基础。 #### 5. Web应用的Manifest文件 Manifest文件是PWA的核心组成部分之一,它是一个简单的JSON文件,为Web应用提供了名称、图标、启动画面、显示方式等配置信息。通过配置Manifest文件,可以定义PWA在用户设备上的安装方式以及应用的外观和行为。 #### 6. 天气信息数据获取 为了提供定期的天气信息,该应用需要接入一个天气信息API服务。开发者可以使用各种公共的或私有的天气API来获取实时天气数据。获取数据后,应用会解析这些数据并将其展示给用户。 #### 7. Web应用的性能优化 在开发过程中,性能优化是确保Web应用反应迅速和资源高效使用的关键环节。常见的优化技术包括但不限于减少HTTP请求、代码分割(code splitting)、懒加载(lazy loading)、优化渲染路径以及使用Preact这样的轻量级库。 #### 8. 压缩包子文件技术 “压缩包子文件”的命名暗示了该应用可能使用了某种形式的文件压缩技术。在Web开发中,这可能指将多个文件打包成一个或几个体积更小的文件,以便更快地加载。常用的工具有Webpack、Rollup等,这些工具可以将JavaScript、CSS、图片等资源进行压缩、合并和优化,从而减少网络请求,提升页面加载速度。 综上所述,本文件描述了一个基于Preact构建的高性能渐进式Web应用,它能够提供定期天气信息。该应用利用了Preact的轻量级特性和PWA技术,以实现快速响应和离线工作的能力。开发者需要了解React框架、Preact的优势、Service Workers、Manifest文件配置、天气数据获取和Web应用性能优化等关键知识点。通过这些技术,可以为用户提供一个加载速度快、交互流畅且具有离线功能的应用体验。
recommend-type

从停机到上线,EMC VNX5100控制器SP更换的实战演练

# 摘要 本文详细介绍了EMC VNX5100控制器的更换流程、故障诊断、停机保护、系统恢复以及长期监控与预防性维护策略。通过细致的准备工作、详尽的风险评估以及备份策略的制定,确保控制器更换过程的安全性与数据的完整性。文中还阐述了硬件故障诊断方法、系统停机计划的制定以及数据保护步骤。更换操作指南和系统重启初始化配置得到了详尽说明,以确保系统功能的正常恢复与性能优化。最后,文章强调了性能测试