`
huiqinbo
  • 浏览: 347815 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

自己动手编写JEECMS自定义栏目统计标签

 
阅读更多

 

今天想在给Java客二级版面加入栏目文章统计效果,如下图,

查看JEECMS的源代码发现开发者版本还没有类似现成的统计标签,一种解决的办法是使用现有的JEECMS标签,像这样Struts( [@cms_content_list channel=id]${tag_list?size}[/@cms_content_list]) ,但是这样的做法非常地低效,原因是[@cms_content_list]标签会把所有当前栏目的文章内容对象查询出来,做全表查询!

没办法啊!!!为了网站访问效率,只好自己写一个统计标签吧。那下面就以[@cms_channel_statistic]为例说下如何在JEECMS加入自定义标签。

 

第一步:编写装载统计信息的Entity

[java] view plaincopy
  1. /** 
  2.  * 频道统计实体类 
  3.  * @author www.javake.net 
  4.  */  
  5. public class ChannelStatistics {  
  6.     /** 
  7.      * 文章总数 
  8.      */  
  9.     private long contentAllCount;  
  10.     /** 
  11.      * 待审核文章总数 
  12.      */  
  13.     private long contentCheckingCount;  
  14.     /** 
  15.      * 评论总数 
  16.      */  
  17.     private long commentCount;  
  18.     /** 
  19.      * 阅读总数 
  20.      */  
  21.     private long viewCount;  
  22.     public long getContentAllCount() {  
  23.         return contentAllCount;  
  24.     }  
  25.     public void setContentAllCount(long contentAllCount) {  
  26.         this.contentAllCount = contentAllCount;  
  27.     }  
  28.     public long getContentCheckingCount() {  
  29.         return contentCheckingCount;  
  30.     }  
  31.     public void setContentCheckingCount(long contentCheckingCount) {  
  32.         this.contentCheckingCount = contentCheckingCount;  
  33.     }  
  34.     public long getCommentCount() {  
  35.         return commentCount;  
  36.     }  
  37.     public void setCommentCount(long commentCount) {  
  38.         this.commentCount = commentCount;  
  39.     }  
  40.     public long getViewCount() {  
  41.         return viewCount;  
  42.     }  
  43.     public void setViewCount(long viewCount) {  
  44.         this.viewCount = viewCount;  
  45.     }  
  46. }  


第二步:编写栏目信息统计的Dao接口。暂时只实现文章总数统计,待审核文章统计,评论总数。

[java] view plaincopy
  1. /** 
  2.  * 栏目信息统计Dao接口 
  3.  * @author www.javake.net 
  4.  */  
  5. public interface CmsChannelStatisticDao {  
  6.     /** 
  7.      * 当前栏目文章统计 
  8.      * @param restrictions 
  9.      * @return 
  10.      */  
  11.     public long contentStatistic(Map<String, Object> restrictions);  
  12.     /** 
  13.      * 当前栏目待审核文章统计 
  14.      * @param restrictions 
  15.      * @return 
  16.      */  
  17.     public long contentCheckingStatistic(Map<String, Object> restrictions);  
  18.     /** 
  19.      * 当前栏目评论统计 
  20.      * @param restrictions 
  21.      * @return 
  22.      */  
  23.     public long commentStatistic(Map<String, Object> restrictions);  
  24. }  


 

第三步:编写Dao接口的实现。

[java] view plaincopy
  1. /** 
  2.  * 栏目信息统计Dao实现类 
  3.  * @author www.javake.net 
  4.  */  
  5. import static com.jeecms.cms.entity.main.Content.ContentStatus.passed;  
  6. import static com.jeecms.cms.entity.main.Content.ContentStatus.prepared;  
  7. import static com.jeecms.cms.entity.main.Content.ContentStatus.rejected;  
  8. import static com.jeecms.cms.statistic.CmsStatistic.CHANNELID;  
  9. import static com.jeecms.cms.statistic.CmsStatistic.ISREPLYED;  
  10. import static com.jeecms.cms.statistic.CmsStatistic.SITEID;  
  11. import java.util.Map;  
  12. import org.springframework.stereotype.Repository;  
  13. import com.jeecms.cms.entity.main.Content.ContentStatus;  
  14. import com.jeecms.common.hibernate3.Finder;  
  15. import com.jeecms.common.hibernate3.HibernateSimpleDao;  
  16. @Repository  
  17. public class CmsChannelStatisticDaoImpl extends HibernateSimpleDao  
  18.             implements CmsChannelStatisticDao{  
  19.     /** 
  20.      * 获取文章总数 
  21.      */  
  22.     public long contentStatistic(Map<String, Object> restrictions) {  
  23.         Finder f = createCacheableFinder("select count(*) from Content bean");  
  24.         Integer channelId = (Integer) restrictions.get(CHANNELID);  
  25.         if (channelId != null) {  
  26.             f.append(" join bean.channel channel,Channel parent");  
  27.             f.append(" where channel.lft between parent.lft and parent.rgt");  
  28.             f.append(" and channel.site.id=parent.site.id");  
  29.             f.append(" and parent.id=:parentId");  
  30.             f.setParam("parentId", channelId);  
  31.         } else {  
  32.             f.append(" where bean.site.id=:siteId").setParam("siteId",  
  33.                     restrictions.get(SITEID));  
  34.         }  
  35.         return (Long) find(f).iterator().next();  
  36.     }  
  37.       
  38.     private long contentStatistic(Map<String, Object> restrictions,ContentStatus status) {  
  39.         Finder f = createCacheableFinder("select count(*) from Content bean");  
  40.         if (prepared == status || passed == status || rejected == status) {  
  41.             f.append(" join bean.contentCheckSet check");  
  42.         }  
  43.         Integer channelId = (Integer) restrictions.get(CHANNELID);  
  44.         if (channelId != null) {  
  45.             f.append(" join bean.channel channel,Channel parent");  
  46.             f.append(" where channel.lft between parent.lft and parent.rgt");  
  47.             f.append(" and channel.site.id=parent.site.id");  
  48.             f.append(" and parent.id=:parentId");  
  49.             f.setParam("parentId", channelId);    
  50.         } else {  
  51.             f.append(" where bean.site.id=:siteId").setParam("siteId",  
  52.                     restrictions.get(SITEID));  
  53.         }  
  54.         if (prepared == status || passed == status) {  
  55.             f.append(" and check.rejected=false");  
  56.         } else if (rejected == status) {  
  57.             f.append(" and check.rejected=true");  
  58.         }  
  59.         return (Long) find(f).iterator().next();  
  60.     }  
  61.       
  62.     /** 
  63.      * 待审核文章总数 
  64.      * @param restrictions 
  65.      * @param status 
  66.      * @return 
  67.      */  
  68.     public long contentCheckingStatistic(Map<String, Object> restrictions) {  
  69.         return contentStatistic(restrictions,ContentStatus.prepared);  
  70.     }  
  71.     public long commentStatistic(Map<String, Object> restrictions) {  
  72.         Finder f = createCacheableFinder("select count(*) from CmsComment bean ");  
  73.         Integer channelId = (Integer) restrictions.get(CHANNELID);  
  74.         if (channelId != null) {  
  75.             f.append(" join bean.channel channel,Channel parent");  
  76.             f.append(" where channel.lft between parent.lft and parent.rgt");  
  77.             f.append(" and channel.site.id=parent.site.id");  
  78.             f.append(" and parent.id=:parentId");  
  79.             f.setParam("parentId", channelId);    
  80.         } else {  
  81.             f.append(" where bean.site.id=:siteId").setParam("siteId",  
  82.                     restrictions.get(SITEID));  
  83.         }  
  84.         Boolean isReplyed = (Boolean) restrictions.get(ISREPLYED);  
  85.         if (isReplyed != null) {  
  86.             if (isReplyed) {  
  87.                 f.append(" and bean.replayTime is not null");  
  88.             } else {  
  89.                 f.append(" and bean.replayTime is null");  
  90.             }  
  91.         }  
  92.         return (Long) find(f).iterator().next();  
  93.     }  
  94.       
  95.     private Finder createCacheableFinder(String hql) {  
  96.         Finder finder = Finder.create(hql);  
  97.         finder.setCacheable(true);  
  98.         return finder;  
  99.     }  
  100. }  


 

第四步:编写栏目统计的FreeMarker标签类。这里可以输入两个参数,一个是id(栏目id),一个是siteId(站点id)。这两个参数可在使用标签的时候输入。

[java] view plaincopy
  1. /** 
  2.  * 栏目统计 
  3.  * @author www.javake.net 
  4.  */  
  5. import static com.jeecms.common.web.freemarker.DirectiveUtils.OUT_BEAN;  
  6. import static freemarker.template.ObjectWrapper.DEFAULT_WRAPPER;  
  7. import static com.jeecms.cms.statistic.CmsStatistic.SITEID;  
  8. import static com.jeecms.cms.statistic.CmsStatistic.ISREPLYED;  
  9. import static com.jeecms.cms.statistic.CmsStatistic.USERID;  
  10. import static com.jeecms.cms.statistic.CmsStatistic.CHANNELID;  
  11. import java.io.IOException;  
  12. import java.util.HashMap;  
  13. import java.util.Map;  
  14. import org.springframework.beans.factory.annotation.Autowired;  
  15. import com.jeecms.cms.entity.main.ChannelStatistics;  
  16. import com.jeecms.cms.entity.main.CmsSite;  
  17. import com.jeecms.cms.statistic.CmsChannelStatisticDao;  
  18. import com.jeecms.cms.web.FrontUtils;  
  19. import com.jeecms.common.web.freemarker.DirectiveUtils;  
  20. import freemarker.core.Environment;  
  21. import freemarker.template.TemplateDirectiveBody;  
  22. import freemarker.template.TemplateDirectiveModel;  
  23. import freemarker.template.TemplateException;  
  24. import freemarker.template.TemplateModel;  
  25. public class CmsChannelStatisticsDirective implements TemplateDirectiveModel{  
  26.     /** 
  27.      * 输入参数,站点ID。存在时,获取该站点栏目,不存在时获取当前站点栏目。 
  28.      */  
  29.     public static final String PARAM_SITE_ID = "siteId";  
  30.     /** 
  31.      * 输入参数,栏目ID。 
  32.      */  
  33.     public static final String PARAM_ID = "id";  
  34.     @SuppressWarnings("unchecked")  
  35.     public void execute(Environment env, Map params, TemplateModel[] loopVars,  
  36.             TemplateDirectiveBody body) throws TemplateException, IOException {  
  37.         CmsSite site = FrontUtils.getSite(env);  
  38.         Integer id = DirectiveUtils.getInt(PARAM_ID, params);  
  39.         ChannelStatistics statistics = null;  
  40.         Map<String,Object> restrictions = new HashMap<String,Object>();  
  41.         Integer siteId = DirectiveUtils.getInt(PARAM_SITE_ID, params);  
  42.         if (siteId == null) {  
  43.             siteId = site.getId();  
  44.         }  
  45.         if (id != null ) {  
  46.             restrictions.put(CHANNELID, id);          
  47.         } else {  
  48.             restrictions.put(SITEID, siteId);  
  49.         }  
  50.         long contentCount = channelSatistic.contentStatistic(restrictions);  
  51.         long contentCheckingCount = channelSatistic.contentCheckingStatistic(restrictions);  
  52.         long commentCount = channelSatistic.commentStatistic(restrictions);  
  53.           
  54.         statistics = new ChannelStatistics();  
  55.         statistics.setCommentCount(commentCount);  
  56.         statistics.setContentAllCount(contentCount);  
  57.         statistics.setContentCheckingCount(contentCheckingCount);  
  58.           
  59.         Map<String, TemplateModel> paramWrap = new HashMap<String, TemplateModel>(  
  60.                 params);  
  61.         paramWrap.put(OUT_BEAN, DEFAULT_WRAPPER.wrap(statistics));  
  62.         Map<String, TemplateModel> origMap = DirectiveUtils  
  63.                 .addParamsToVariable(env, paramWrap);  
  64.         body.render(env.getOut());  
  65.         DirectiveUtils.removeParamsFromVariable(env, paramWrap, origMap);  
  66.     }  
  67.       
  68.     @Autowired  
  69.     private CmsChannelStatisticDao channelSatistic;  
  70.   
  71.     public void setChannelSatistic(CmsChannelStatisticDao channelSatistic) {  
  72.         this.channelSatistic = channelSatistic;  
  73.     }  
  74. }  


 

第五步:在jeecms-context.xml文件中加入CmsChannelStatisticsDirective标签类的bean注入代码。

<!— Author:www.javake.net -->

<bean id="cms_lucene_page"class="com.jeecms.cms.lucene.LuceneDirectivePage"/>

<bean id="cms_advertising"class="com.jeecms.cms.action.directive.CmsAdvertisingDirective"/>

<bean id="cms_channel_statistic" class="com.jeecms.cms.action.directive.CmsChannelStatisticsDirective"/>

 

<!— Author:www.javake.net -->

<property name="freemarkerVariables">

        <map>

            <entry key="uuid"value-ref="uuid"/>

            <entry key="process_time"value-ref="process_time"/>

            <entry key="text_cut"value-ref="text_cut"/>

            <entry key="html_cut"value-ref="html_cut"/>

            <entry key="cms_pagination"value-ref="cms_pagination"/>

            <entry key="cms_channel_list"value-ref="cms_channel_list"/>

            <entry key="cms_channel_page"value-ref="cms_channel_page"/>

            <entry key="cms_channel"value-ref="cms_channel"/>

            <entry key="cms_content"value-ref="cms_content"/>

            <entry key="cms_content_list"value-ref="cms_content_list"/>

            <entry key="cms_content_page"value-ref="cms_content_page"/>

            <entry key="cms_tag_list"value-ref="cms_tag_list"/>

            <entry key="cms_tag_page"value-ref="cms_tag_page"/>

            <entry key="cms_topic_list"value-ref="cms_topic_list"/>

            <entry key="cms_topic_page"value-ref="cms_topic_page"/>

            <entry key="cms_comment_list"value-ref="cms_comment_list"/>

            <entry key="cms_comment_page"value-ref="cms_comment_page"/>

            <entry key="cms_guestbook_ctg_list"value-ref="cms_guestbook_ctg_list"/>

            <entry key="cms_guestbook_list"value-ref="cms_guestbook_list"/>

            <entry key="cms_guestbook_page"value-ref="cms_guestbook_page"/>

            <entry key="cms_vote"value-ref="cms_vote"/>

            <entry key="cms_friendlink_ctg_list"value-ref="cms_friendlink_ctg_list"/>

            <entry key="cms_friendlink_list"value-ref="cms_friendlink_list"/>

            <entry key="cms_lucene_list"value-ref="cms_lucene_list"/>

            <entry key="cms_lucene_page"value-ref="cms_lucene_page"/>

            <entry key="cms_advertising"value-ref="cms_advertising"/>

            <entry key="cms_channel_statistic" value-ref="cms_channel_statistic"/>

            </map>

        </property>

 

第六步:在jeecms-servlet-front.xml文件中配置

<!— Author:www.javake.net -->

<bean id="freemarkerConfig"class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">

        <property name="freemarkerVariables">

            <map>

            <entry key="uuid"value-ref="uuid"/>

            <entry key="process_time"value-ref="process_time"/>

            <entry key="text_cut"value-ref="text_cut"/>

            <entry key="html_cut"value-ref="html_cut"/>

            <entry key="cms_pagination"value-ref="cms_pagination"/>

            <entry key="cms_channel_list"value-ref="cms_channel_list"/>

            <entry key="cms_channel_page"value-ref="cms_channel_page"/>

            <entry key="cms_channel"value-ref="cms_channel"/>

            <entry key="cms_content"value-ref="cms_content"/>

            <entry key="cms_content_list"value-ref="cms_content_list"/>

            <entry key="cms_content_page"value-ref="cms_content_page"/>

            <entry key="cms_tag_list"value-ref="cms_tag_list"/>

            <entry key="cms_tag_page"value-ref="cms_tag_page"/>

            <entry key="cms_topic_list"value-ref="cms_topic_list"/>

            <entry key="cms_topic_page"value-ref="cms_topic_page"/>

            <entry key="cms_comment_list"value-ref="cms_comment_list"/>

            <entry key="cms_comment_page"value-ref="cms_comment_page"/>

            <entry key="cms_guestbook_ctg_list"value-ref="cms_guestbook_ctg_list"/>

            <entry key="cms_guestbook_list"value-ref="cms_guestbook_list"/>

            <entry key="cms_guestbook_page"value-ref="cms_guestbook_page"/>

            <entry key="cms_vote"value-ref="cms_vote"/>

            <entry key="cms_lucene_list"value-ref="cms_lucene_list"/>

            <entry key="cms_lucene_page"value-ref="cms_lucene_page"/>

            <entry key="cms_friendlink_ctg_list"value-ref="cms_friendlink_ctg_list"/>

            <entry key="cms_friendlink_list"value-ref="cms_friendlink_list"/>

            <entry key="cms_advertising"value-ref="cms_advertising"/>

            <entry key="cms_channel_statistic" value-ref="cms_channel_statistic"/>

            </map>

        </property>

 

第七步:到目前为止,核心代码和配置编写完毕啦!!!可以在栏目模板中使用标签了!

<!—Author:www.javake.net-->

( [@cms_channel_statisticid=a.id]${tag_bean.contentAllCount}[/@cms_channel_statistic] )

 

分享到:
评论

相关推荐

    jeecms 标签 使用说明

    这涉及到Java的标签库开发技术,包括编写标签处理类和标签库描述文件(TLD),然后将自定义标签部署到Jeecms环境中。 六、模板标签说明文档 在提供的文件`jss_CMS标签说明.doc`和`jeecms模板标签说明.doc`中,详细...

    jeecms3.X标签整理

    Jeecms 3.x 标签是用于构建动态网站内容的一种强大的工具,它允许开发者通过简单的标签语法来实现复杂的功能,而无需编写大量的Java代码。以下是对Jeecms 3.x 标签的详细解释: 1. 页面模板包含标签 `[#include ".....

    jeecms2012标签使用教程

    在Jeecms中,标签是预定义的功能块,它们允许开发者在模板中插入动态内容,而无需编写复杂的Java代码。这些标签涵盖了诸如文章列表、分类导航、评论展示、搜索功能等多种常见网站元素。下面将详细介绍一些核心的...

    Jeecms2012版标签学习手册

    以上四个标签是Jeecms2012版中常用的几个标签,它们不仅简化了开发过程中的代码编写工作,也极大地提升了网站的功能性和用户体验。合理运用这些标签能够帮助开发者构建出更加高效、易维护的Web应用程序。

    jeecms标签

    在编写模板时,要确保标签使用的范围正确,例如,在首页模板或栏目页模板中使用。 接下来,我们转向`[@cms.ArtiList /]`标签。这是Jeecms中最常用的标签之一,用于获取和展示文章列表。通过调整不同的参数,你可以...

    JEECMS

    - **构建栏目结构**:自定义网站的栏目层次,调整内容的分类展示。 - **设置网站参数**:调整网站的全局配置,如域名、主题、SEO设置等。 **五、JEECMS的社区支持和持续发展** 作为一个开源项目,JEECMS有活跃的...

    JEECMSV9.x系统使用说明书 -美工篇

    例如,可以使用`&lt;jeecms:nav&gt;`标签来创建导航菜单,该标签可以根据配置生成多级导航,并支持自定义样式和扩展属性。 ### 2、栏目当前位置 `&lt;jeecms:currentNav&gt;`标签用于显示当前页面所属的栏目路径,帮助用户理解...

    jeecms introduction

    - **高度定制化**: 用户可以通过自定义标签等方式实现内容和展示方式的个性化配置。 - **搜索引擎优化**: 内置SEO优化机制,提升网站在搜索引擎中的可见度。 - **全站静态化**: 自动生成全站静态页面,显著提高页面...

    jeecmsv5 eclipse

    5. **搜索引擎优化**:考虑到现代网站对SEO的需求,JeecmsV5内置了友好的SEO设置,包括自定义URL、关键词设置、元标签等,有助于提升网站在搜索引擎中的排名。 6. **Eclipse集成**:在Eclipse环境下开发JeecmsV5...

    信息系统分析与设计 CMS系统完成实验报告

    ##### 编写目的 本文档旨在详细阐述“网站内容管理系统(CMS)”的设计与实现过程,特别是从需求分析、功能规划到技术选型等多个方面进行深入探讨。通过对项目的背景、目标及预期效果的说明,为后续开发工作提供明确指导...

Global site tag (gtag.js) - Google Analytics