经过前两篇文章(大话分页一大话分页二)的介绍,我认为我想介绍的东西已经介绍完了,不过想精益求精的童鞋可以继续看本篇文章。

在第一篇文章中介绍了一个分页的工具类(具体请看大话分页一),从实现功能上来说,它没有任何问题,不过就OO思想来说,这个类是有一点问题的:实现分页,我们是要用到offSet和pageSize两个参数,也就是说他们是必须的。可是我们每当使用到分页的时候,除了穿业务逻辑所需的参数,还需要传递这两个参数。这样,方法未免有些太过冗长,有没有一种方法,可以让它自动传递这两个参数,开发人员不用手动去管它呢?它就是threadlocal。

下面SystemContext这个类里面就用Threadlocal封装了offSet和pageSize两个参数,并依次定义了他们的get、set和remove方法。

package com.lzq;

/**
* 使用threadLocal简化API
* 由于封装的分页类AbstractPageManager,中的方法参数offSet和pageSize必要但是每个方法都必须写
* 所以使用threadLocal简化
* @author lzq
*
*/
public class SystemContext {
//定义两个threadLocal变量:offSet和pageSize
private static ThreadLocal<Integer> offSet = new ThreadLocal<Integer>();
private static ThreadLocal<Integer> pageSize = new ThreadLocal<Integer>();
/*
* offset :get、set、remove
*/
public static int getOffSet() {
Integer os =offSet.get();
if (os == null) {
return 0;
}
return os;
}
public static void setOffSet(int offSetValue) {
offSet.set(offSetValue);
}
public static void removeOffSet(){
offSet.remove();
}
/*
* pageSize :get、set、remove
*/
public static int getPageSize() {
Integer ps = pageSize.get();
if (ps == null) {
return 0;
}
return ps;
}
public static void setPageSize(int pageSizeValue) {
pageSize.set(pageSizeValue);
}
public static void removePageSize(){
pageSize.remove();
}
}

PageFilter,用于获取前台传过来的offset的值以及设置pageSize的值。

package com.lzq.web;

import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import com.lzq.SystemContext; /**
* 分页Filter,用于获取offSet和pageSize的值
* @author lzq
*
*/
public class PageFilter implements Filter {
@Override
public void destroy() {} @Override
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest=(HttpServletRequest)request; SystemContext.setOffSet(getOffSet(httpRequest));
SystemContext.setPageSize(getPageSize()); try {
chain.doFilter(request, response);
}
//使用完Threadlocal,将其删除。使用finally确保一定将其删除
finally{
SystemContext.removeOffSet();
SystemContext.removePageSize();
}
}
/**
* 获得pager.offset参数的值
* @param request
* @return
*/
protected int getOffSet(HttpServletRequest request) {
int offSet = 0;
try {
String pageOff = request.getParameter("pager.offset");
if (pageOff != null) {
offSet =Integer.parseInt(pageOff);
}
} catch (NumberFormatException e) {
e.printStackTrace();
}
return offSet;
}
/**
* 设置默认每页大小
* @return
*/
protected int getPageSize() {
return 4;
}
@Override
public void init(FilterConfig arg0) throws ServletException {}
}

在web.xml配置文件中对filter进行配置:

  <filter>
<filter-name>PageFilter</filter-name>
<filter-class>com.lzq.web.PageFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>PageFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

在工具类AbstractPageManager中,另外增加下面几个重载的工具API方法,以达到减少参数的目的。

package com.lzq.manager.impl;

import org.hibernate.Query;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import com.lzq.PageModel;
import com.lzq.SystemContext;
import com.lzq.manager.SystemException;
/**
* 简化的分页API
* @author lzq
*
*/
public class AbstractPageManager extends HibernateDaoSupport { /**
* 通过调用这些工具方法,简化API
* @param hql
* @return
*/
public PageModel searchPaginate(String hql){
return searchPaginate(hql,null,SystemContext.getOffSet(),SystemContext.getPageSize());
}
public PageModel searchPaginate(String hql, Object param){
return searchPaginate(hql,new Object[]{param},SystemContext.getOffSet(),SystemContext.getPageSize());
}
public PageModel searchPaginate(String hql, int offSet, int pageSize){
return searchPaginate(hql,null,offSet,pageSize);
}
public PageModel searchPaginate(String hql, Object param, int offSet, int pageSize){
return searchPaginate(hql,new Object[]{param},offSet,pageSize);
}
}

测试调用的方法:

/**
* 测试方法
*
* @param parentId
* @return
*/
@Override
public PageModel findOrgList(int id) {
PageModel pageModel = null;
                String txtSQL =  "from Organization o where o.parent.id= ?";
                pageModel = searchPaginate(txtSQL, id);
return pageModel;
}

至此,就更有点面向对象的意思了。编程中感觉别扭的时候,就该停下来想一想是不是自己太将就了。真正的程序员该干的活不是ctrl C 和 ctrl V,而是那些有思考的代码。

大话分页(补充)——Threadlocal封装offSet和pageSize简化分页工具类的更多相关文章

  1. 封装关于金额计算的double工具类

    由于直接使用double类型的加减乘除,可能会出现不可预测的问题,精度丢失等等.在业务中,计算金额是一件很重要的事情. 可以直接使用BigDecimal类,进行加减乘除.相关BigDecimal类介绍 ...

  2. java反射的补充:桥接方法以及Spring中一些工具类

    在上一篇博文中:http://www.cnblogs.com/guangshan/p/4660564.html 源码中有些地方用到了 this.bridgedMethod = BridgeMethod ...

  3. Java 200+ 面试题补充 ThreadLocal 模块

    让我们每天都有进步,老王带你打造最全的 Java 面试清单,认真把一件事做到极致. 本文是前文<Java 最常见的 200+ 面试题>的第一个补充模块. 1.ThreadLocal 是什么 ...

  4. iOS开发拓展篇—封装音频文件播放工具类

    iOS开发拓展篇—封装音频文件播放工具类 一.简单说明 1.关于音乐播放的简单说明 (1)音乐播放用到一个叫做AVAudioPlayer的类 (2)AVAudioPlayer常用方法 加载音乐文件 - ...

  5. 自己封装的poi操作Excel工具类

    自己封装的poi操作Excel工具类 在上一篇文章<使用poi读写Excel>中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类. 该工具类主要完 ...

  6. 【01-14】java ThreadLocal工具类

    自定义ThreadLocal package concurrent; import java.util.HashMap; import java.util.Map; /** * @author alo ...

  7. 轻量级封装DbUtils&Mybatis之三MyBatis分页

    MyBatis假分页 参考DefaultResultSetHandler的skipRows方法. 温馨提示:部分代码请参考轻量级封装DbUtils&Mybatis之一概要 解决方案 1)之前公 ...

  8. SQL Server 2012使用Offset/Fetch Next实现分页

    在Sql Server 2012之前,实现分页主要是使用ROW_NUMBER(),在SQL Server2012,可以使用Offset ...Rows  Fetch Next ... Rows onl ...

  9. 【SSH】——封装参数不确定的分页查询

    [前言] 在BS中,分页技术的应用相当频繁.说到分页,简单的分页就很好实现了,如果在分页的基础上再加上业务逻辑,这就使得分页的技术更加的灵活了. [简单分页] 我们先看一种简单的分页,为了做到复用,我 ...

随机推荐

  1. WebMagic的设计参考了业界最优秀的爬虫Scrapy

    http://webmagic.io/docs/zh/posts/ch1-overview/thinking.html https://github.com/psvehla/liferay-sprin ...

  2. hdu 4940 无源汇有上下界最大流

    /* <img src="http://img.blog.csdn.net/20140823174212937?watermark/2/text/aHR0cDovL2Jsb2cuY3N ...

  3. Sybase常用函数

    ==================================常用函数===========================================字符串函数1)ISNULL(EXP1, ...

  4. css部分总结

    10.19HTML总结 1.<!DOCTYPE HTML>声明:告知浏览器文档使用哪种HTML或者XHTML规范,该标签可声明三种DTD(文档类型定义)类型:严格版本.过渡版本以及基于框架 ...

  5. winform中获取Properties窗口的值.

    我写这个工具,主要是多次在将自己的代码和别人代码做对比时,不想繁琐地用眼看他设置的和自己设置的哪里不一样. using System; using System.Collections.Generic ...

  6. x++ and ++x

    http://blog.sina.com.cn/s/blog_6c762bb30101ar1w.html 看到个东西,搞不清的时候可以看看 =.=

  7. SSAS数据集Cube不存在或者尚未处理

    对Microsoft SQL Server(2008) Analysis Services(以下称SSAS) 多维数据集运行多维表达式 (MDX) 查询时,会返回这个错误消息:XXX Cube不存在, ...

  8. iOS 点击cell下拉

    iOS  点击cell下拉 代码如下: #import "ViewController.h" @interface ViewController ()<UITableView ...

  9. SignalR2.0开发实例之——私聊

    一.前言 继续上一章的补充,这章介绍使用私聊的功能.主要通过一个方法   Clients.Client(Context.ConnectionId).showMessage(msg); SignalR框 ...

  10. _CrtMemBlockHeader

    typedef struct _CrtMemBlockHeader{// Pointer to the block allocated just before this one:struct _Crt ...