`
aa00aa00
  • 浏览: 333064 次
  • 性别: Icon_minigender_1
  • 来自: 沈阳
文章分类
社区版块
存档分类
最新评论

ssh+pager taglib分页实现

阅读更多

pager-taglib分页封装整合SSH

   使用ThreadLocal 模式,将分页大小及分页开始条数保存下来

public class SystemContext {

 private static ThreadLocal offset = new ThreadLocal();
 private static ThreadLocal pagesize = new ThreadLocal();
 
 public static void setOffset(int _offset){
  offset.set(_offset);
 }
 
 public static int getOffset(){
  Integer _offset = (Integer)offset.get();
  if(_offset == null){
   return 0;
  }
  return _offset;
 }
 
 public static void removeOffset(){
  offset.remove();
 }
 
 public static void setPagesize(int _pagesize){
  pagesize.set(_pagesize);
 }
 
 public static int getPagesize(){
  Integer _pagesize = (Integer)pagesize.get();
  if(_pagesize == null){
   return Integer.MAX_VALUE;
  }
  return _pagesize;
 }
 
 public static void removePagesize(){
  pagesize.remove();
 }
}

 

建立PagerFilter,是每次页面请求,都被PagerFilter截获,设置分页的参数大小!

public class PagerFilter implements Filter {

 public void destroy() {
 }

 public void doFilter(ServletRequest request, ServletResponse response,
   FilterChain chain) throws IOException, ServletException {
  
  HttpServletRequest httpRequest = (HttpServletRequest)request;
  
  SystemContext.setOffset(getOffset(httpRequest));
  SystemContext.setPagesize(getPagesize(httpRequest));
  
  try{
   chain.doFilter(request, response);
  }finally{
   SystemContext.removeOffset();
   SystemContext.removePagesize();
  }
 }
 
 private int getOffset(HttpServletRequest request){
  int offset = 0;
  try {
   offset = Integer.parseInt(request.getParameter("pager.offset"));  //pager-taglib分页的参数
  } catch (Exception ignore) {
  }
  return offset;
 }
 
 private int getPagesize(HttpServletRequest request){
  return 10;
 }

 public void init(FilterConfig arg0) throws ServletException {
 }

}

 

使用Hibernate 实现通用的分页实现

public abstract class AbstractDao extends HibernateDaoSupport {
 
 public PagerModel searchPaginated(String hql){
  return searchPaginated(hql, null);
 }
 
 public PagerModel searchPaginated(String hql,Object value){
  return searchPaginated(hql, new Object[]{value});
 }
 
 public PagerModel searchPaginated(String hql,Object[] values){
  return searchPaginated(hql, values, SystemContext.getOffset(), SystemContext.getPagesize());
 }

 
 
 public PagerModel searchPaginated(String hql,int offset,int pagesize) {
  return this.searchPaginated(hql, null, offset, pagesize);
 }
 
 public PagerModel searchPaginated(String hql,Object value,int offset,int pagesize) {
  return this.searchPaginated(hql,  new Object[]{value}, offset, pagesize);
 }

 /**
  *
  * @param hql
  * @param values
  * @param offset
  * @param pagesize
  * @return
  */
 @SuppressWarnings("unchecked")
 public PagerModel searchPaginated(String hql,Object[] values,int offset,int pagesize) {
  //获得总记录数
  String countHql = getCountQuery(hql);
  Query query = this.getSession().createQuery(countHql);
  if(values != null && values.length>0) {
   for (int i=0; i<values.length;i++) {
    query.setParameter(i, values[i]);
   }
  }
  int total = ((Long)query.uniqueResult()).intValue();
  
  //获得当前页的数据
  query = this.getSession().createQuery(hql);
  if(values != null && values.length>0) {
   for (int i=0; i<values.length;i++) {
    query.setParameter(i, values[i]);
   }
  }
  query.setFirstResult(offset);
  query.setMaxResults(pagesize);
  List datas =query.list();
  PagerModel pm = new PagerModel();
  pm.setTotal(total);
  pm.setDatas(datas);
  return pm; 
 }
 
 /**
  * 根据HQL语句,获得查询总记录数的HQL语句
  * 如:
  * select o from Organization o where o.parent is null
  * 经过转换,得到
  * select count(*) from Organization o where o.parent is null
  * @param hql
  * @return
  */
 private String getCountQuery(String hql) {
  int beginIndex = hql.indexOf("from");
  
  if(beginIndex != -1) {
   String countHql= "select count(*) " + hql.substring(beginIndex);
   return countHql;
  }else {
   throw new SystemException("无效的HQL查询语句【"+hql+"】");
  }
 }
 
 
}

 

public class PagerModel {
 
 private int total;
 
 private List datas;

 public int getTotal() {
  return total;
 }

 public void setTotal(int total) {
  this.total = total;
 }

 public List getDatas() {
  return datas;
 }

 public void setDatas(List datas) {
  this.datas = datas;
 }

}

分享到:
评论

相关推荐

    ssh2+pager-taglib实现自动分页

    Pager-taglib,支持多种风格的分页显示。实际上她是一个Jsp标签库,为在JSP上显示分页信息而设计的一套标签,通过这些标签的不同的组合,会形成多种不一样的分页页面,风格各异,她自带的DEMO就有七种左右的分页风格...

    ssh+分页(pager-taglib)

    本资源融合了struts+spring+hibernate的集成,并充分运用jsp开源分页标签(pager-taglib)进行了分页。支持多条件的分页查询。由于上传大小限制,本人被迫将所用到的jar包目录删除,所需的几个必备jar包我已留在本...

    使用pager-taglib实现分页显示的详细步骤

    本文将详细介绍如何利用`pager-taglib`结合SSH(Struts、Spring、Hibernate)框架实现从前端到后端的分页功能。 #### 一、准备工作 在开始之前,确保项目环境中已经引入了Struts、Spring、Hibernate以及`pager-...

    pager-taglib实现Google分页

    本主题将深入探讨如何利用pager-taglib库实现类似于Google的高效分页效果,该库是基于Spring、Struts和Hibernate(SSH)框架的。下面我们将详细讲解相关知识点。 首先,** pager-taglib **是一个自定义的JSP标签库...

    OA pagertaglib ssh2 增删改查

    本项目以“OA pagertaglib ssh2 增删改查”为主题,涉及到的关键技术包括SSH2框架、PagerTaglib分页库以及增删改查的基础操作。 首先,SSH2是指Spring、Struts2和Hibernate这三个开源框架的组合,它们是Java Web...

    SSHConformity【display标签和taglib标签缺架包】,ssh整合,分页,display标签,pager-taglib标签

    总的来说,SSHConformity项目展示了如何通过SSH整合实现企业级应用,而Display Tag和Pager Taglib的使用则优化了数据展示和分页操作,提高了用户体验。在实际开发中,理解并掌握这些技术将有助于构建高效、易维护的...

    Pager Tag Lib分页操作源码

    Pager Tag Lib库就是一种用于实现分页功能的标签库,它可以极大地简化开发者的工作,无需编写复杂的分页算法。本篇文章将深入探讨Pager Tag Lib在SSH2(Spring、Struts2、Hibernate2)框架中结合JSTL的使用方法和...

    java学生成绩管理系统源码数据库 MySQL源码类型 WebForm

    JAVA学生成绩管理系统源码 开发语言:JAVA, 框架:SSH+Mysql+jsp (struts2 + spring + hibernate) 带有Mysql数据库和漂亮的后台管理功能 ... 分页使用的是pager-taglib框架 7. 后台登陆使用的是frameset框架

    S2SH整合pager-taglibs示例

    本示例主要关注的是如何在Struts2框架中整合`pager-taglibs`,它是一个强大的分页标签库,能够帮助开发者在页面上轻松实现数据的分页展示,提升用户体验。`pager-taglibs`使得在JSP页面中处理大量数据变得更加简洁...

    标签: OA 项目 SSH2 增删改查

    分页功能是大型系统中常见的需求,本项目利用了pager-taglib库来实现这一功能。Pager-taglib是基于JSP标签库的一种分页工具,它可以在页面上显示分页链接,同时处理分页请求,为查询结果进行分页显示。这种方式使得...

    OA 项目 SSH2 增删改查

    这个OA项目使用了`pager-taglib`标签库进行分页,这是一款基于JSTL的分页标签,它可以方便地在JSP页面中实现动态的分页效果,减轻服务器负载,提升用户体验。 6. **组织管理与人员管理**:在OA系统中,这两部分涉及...

    企业管理OA系统

    "分页利用了pager-taglib",这意味着开发团队使用了自定义的JSP标签库来实现页面的分页显示。Pager-taglib通常提供了一种简便的方式来分页查询数据库,它可以帮助优化性能,避免一次性加载大量数据到页面,提高用户...

    SSH集成所需要的jar包

    - `pager-taglib.jar`: 这个库提供了分页标签,方便在JSP页面中实现数据的分页显示。 这些jar包共同构成了SSH集成的基础,使得开发者可以构建出结构清晰、易于维护的Java Web应用程序。通过Struts处理用户请求,...

Global site tag (gtag.js) - Google Analytics