关于分页的处理
public class UserReportVo {
private String uid;
/**
* 分頁對象
*/
private Page<UserReportVo> page;
public Page<UserReportVo> getPage() {
return page;
}
public void setPage(Page<UserReportVo> page) {
this.page = page;
}
public String getUid() {
return uid;
}
public void setUid(String uid) {
this.uid = uid;
}
}
?
?
public class Page<T> {
protected int pageNo = 1; // 當(dāng)前頁碼
protected int pageSize = Integer.valueOf(Global.getConfig("page.pageSize")); // 頁面大小,設(shè)置為“-1”表示不進(jìn)行分頁(分頁無效)
protected long count;// 總記錄數(shù),設(shè)置為“-1”表示不查詢總數(shù)
protected int first;// 首頁索引
protected int last;// 尾頁索引
protected int prev;// 上一頁索引
protected int next;// 下一頁索引
private boolean firstPage;//是否是第一頁
private boolean lastPage;//是否是最后一頁
protected int length = 8;// 顯示頁面長度
protected int slider = 1;// 前后顯示頁面長度
private List<T> list = new ArrayList<T>();
private String orderBy = ""; // 標(biāo)準(zhǔn)查詢有效, 實(shí)例: updatedate desc, name asc
protected String funcName = "page"; // 設(shè)置點(diǎn)擊頁碼調(diào)用的js函數(shù)名稱,默認(rèn)為page,在一頁有多個分頁對象時使用。
protected String funcParam = ""; // 函數(shù)的附加參數(shù),第三個參數(shù)值。
private String message = ""; // 設(shè)置提示消息,顯示在“共n條”之后
public Page() {
this.pageSize = -1;
}
/**
* 構(gòu)造方法
* @param request 傳遞 repage 參數(shù),來記住頁碼
* @param response 用于設(shè)置 Cookie,記住頁碼
*/
public Page(HttpServletRequest request, HttpServletResponse response){
this(request, response, -2);
}
/**
* 構(gòu)造方法
* @param request 傳遞 repage 參數(shù),來記住頁碼
* @param response 用于設(shè)置 Cookie,記住頁碼
* @param defaultPageSize 默認(rèn)分頁大小,如果傳遞 -1 則為不分頁,返回所有數(shù)據(jù)
*/
public Page(HttpServletRequest request, HttpServletResponse response, int defaultPageSize){
// 設(shè)置頁碼參數(shù)(傳遞repage參數(shù),來記住頁碼)
String no = request.getParameter("pageNo");
if (StringUtils.isNumeric(no)){
CookieUtils.setCookie(response, "pageNo", no);
this.setPageNo(Integer.parseInt(no));
}else if (request.getParameter("repage")!=null){
no = CookieUtils.getCookie(request, "pageNo");
if (StringUtils.isNumeric(no)){
this.setPageNo(Integer.parseInt(no));
}
}
// 設(shè)置頁面大小參數(shù)(傳遞repage參數(shù),來記住頁碼大小)
String size = request.getParameter("pageSize");
if (StringUtils.isNumeric(size)){
CookieUtils.setCookie(response, "pageSize", size);
this.setPageSize(Integer.parseInt(size));
}else if (request.getParameter("repage")!=null){
no = CookieUtils.getCookie(request, "pageSize");
if (StringUtils.isNumeric(size)){
this.setPageSize(Integer.parseInt(size));
}
}else if (defaultPageSize != -2){
this.pageSize = defaultPageSize;
}
// 設(shè)置排序參數(shù)
String orderBy = request.getParameter("orderBy");
if (StringUtils.isNotBlank(orderBy)){
this.setOrderBy(orderBy);
}
}
/**
* 構(gòu)造方法
* @param pageNo 當(dāng)前頁碼
* @param pageSize 分頁大小
*/
public Page(int pageNo, int pageSize) {
this(pageNo, pageSize, 0);
}
/**
* 構(gòu)造方法
* @param pageNo 當(dāng)前頁碼
* @param pageSize 分頁大小
* @param count 數(shù)據(jù)條數(shù)
*/
public Page(int pageNo, int pageSize, long count) {
this(pageNo, pageSize, count, new ArrayList<T>());
}
/**
* 構(gòu)造方法
* @param pageNo 當(dāng)前頁碼
* @param pageSize 分頁大小
* @param count 數(shù)據(jù)條數(shù)
* @param list 本頁數(shù)據(jù)對象列表
*/
public Page(int pageNo, int pageSize, long count, List<T> list) {
this.setCount(count);
this.setPageNo(pageNo);
this.pageSize = pageSize;
this.list = list;
}
/**
* 初始化參數(shù)
*/
public void initialize(){
//1
this.first = 1;
this.last = (int)(count / (this.pageSize < 1 ? 20 : this.pageSize) + first - 1);
if (this.count % this.pageSize != 0 || this.last == 0) {
this.last++;
}
if (this.last < this.first) {
this.last = this.first;
}
if (this.pageNo <= 1) {
this.pageNo = this.first;
this.firstPage=true;
}
if (this.pageNo >= this.last) {
this.pageNo = this.last;
this.lastPage=true;
}
if (this.pageNo < this.last - 1) {
this.next = this.pageNo + 1;
} else {
this.next = this.last;
}
if (this.pageNo > 1) {
this.prev = this.pageNo - 1;
} else {
this.prev = this.first;
}
//2
if (this.pageNo < this.first) {// 如果當(dāng)前頁小于首頁
this.pageNo = this.first;
}
if (this.pageNo > this.last) {// 如果當(dāng)前頁大于尾頁
this.pageNo = this.last;
}
}
/**
* 默認(rèn)輸出當(dāng)前分頁標(biāo)簽
* <div class="page">${page}</div>
*/
@Override
public String toString() {
StringBuilder sb = new StringBuilder();
sb.append("<div class=\"span5\" style=\"display: inline;\">");
long startIndex = (pageNo-1)*pageSize + 1;
long endIndex = pageNo*pageSize <=count? pageNo*pageSize:count;
sb.append("<div class=\"dataTables_info\">");
sb.append("<span >顯示第 "+startIndex+" 到第 "+ endIndex +" 條,總共 "+count+" 條</span>");
sb.append("<span >每頁顯示 <span class=\"btn-group dropup\">");
sb.append("<button type=\"button\" class=\"btn btn-default btn-outline dropdown-toggle\" data-toggle=\"dropdown\" aria-expanded=\"false\">");
sb.append("<span class=\"page-size\">"+pageSize+"</span> <span class=\"caret\"></span>");
sb.append("</button>");
sb.append("<ul class=\"dropdown-menu\" role=\"menu\">");
sb.append("<li class=\""+getSelected(pageSize,10)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",10,'"+funcParam+"');\">10</a></li>");
sb.append("<li class=\""+getSelected(pageSize,25)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",25,'"+funcParam+"');\">25</a></li>");
sb.append("<li class=\""+getSelected(pageSize,50)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",50,'"+funcParam+"');\">50</a></li>");
sb.append("<li class=\""+getSelected(pageSize,100)+ "\"><a href=\"javascript:"+funcName+"("+pageNo+",100,'"+funcParam+"');\">100</a></li>");
sb.append("</ul>");
sb.append("</span> 條記錄</span>");
sb.append("</div>");
sb.append("</div>");
sb.append("<div class=\"span7\" style=\"display: inline;\">");
sb.append("<div class=\"dataTables_paginate paging_bootstrap pagination\">");
sb.append("<ul class=\"pagination pagination-outline\">");
if (pageNo == first) {// 如果是首頁
sb.append("<li class=\"prev disabled\"><a href=\"javascript:\">首頁</a></li>\n");
sb.append("<li class=\"prev disabled\"><a href=\"javascript:\">上一頁</a></li>\n");
} else {
sb.append("<li class=\"prev\"><a href=\"javascript:\" οnclick=\""+funcName+"("+first+","+pageSize+",'"+funcParam+"');\">"
+ "首頁></a></li>\n");
sb.append("<li class=\"prev\"><a href=\"javascript:\" οnclick=\""+funcName+"("+prev+","+pageSize+",'"+funcParam+"');\">"
+ "上一頁</a></li>\n");
}
int begin = pageNo - (length / 2);
if (begin < first) {
begin = first;
}
int end = begin + length - 1;
if (end >= last) {
end = last;
begin = end - length + 1;
if (begin < first) {
begin = first;
}
}
if (begin > first) {
int i = 0;
for (i = first; i < first + slider && i < begin; i++) {
sb.append("<li><a href=\"javascript:\" οnclick=\""+funcName+"("+i+","+pageSize+",'"+funcParam+"');\">"
+ (i + 1 - first) + "</a></li>\n");
}
if (i < begin) {
sb.append("<li><a href=\"javascript:\">...</a></li>\n");
}
}
for (int i = begin; i <= end; i++) {
if (i == pageNo) {
sb.append("<li class=\"active\"><a href=\"javascript:\">" + (i + 1 - first)
+ "</a></li>\n");
} else {
sb.append("<li><a href=\"javascript:\" οnclick=\""+funcName+"("+i+","+pageSize+",'"+funcParam+"');\">"
+ (i + 1 - first) + "</a></li>\n");
}
}
if (last - end > slider) {
sb.append("<li class=\"disabled\"><a href=\"javascript:\">...</a></li>\n");
end = last - slider;
}
for (int i = end + 1; i <= last; i++) {
sb.append("<li><a href=\"javascript:\" οnclick=\""+funcName+"("+i+","+pageSize+",'"+funcParam+"');\">"
+ (i + 1 - first) + "</a></li>\n");
}
if (pageNo == last) {
sb.append("<li class=\"next disabled\"><a href=\"javascript:\">下一頁</a></li>\n");
sb.append("<li class=\"next disabled\"><a href=\"javascript:\">尾頁</a></li>\n");
} else {
sb.append("<li class=\"next\"><a href=\"javascript:\" οnclick=\""+funcName+"("+next+","+pageSize+",'"+funcParam+"');\">"
+ "下一頁</a></li>\n");
sb.append("<li class=\"next\"><a href=\"javascript:\" οnclick=\""+funcName+"("+last+","+pageSize+",'"+funcParam+"');\">"
+ "尾頁</a></li>\n");
}
sb.append("</ul>");
sb.append("</div>");
sb.append("</div>");
sb.append("</div>");
return sb.toString();
}
protected String getSelected(int pageNo, int selectedPageNo){
if(pageNo == selectedPageNo){
//return "selected";
return "active";
}else{
return "";
}
}
/**
* 獲取分頁HTML代碼
* @return
*/
public String getHtml(){
return toString();
}
/**
* 獲取設(shè)置總數(shù)
* @return
*/
public long getCount() {
return count;
}
/**
* 設(shè)置數(shù)據(jù)總數(shù)
* @param count
*/
public void setCount(long count) {
this.count = count;
if (pageSize >= count){
pageNo = 1;
}
}
/**
* 獲取當(dāng)前頁碼
* @return
*/
public int getPageNo() {
return pageNo;
}
/**
* 設(shè)置當(dāng)前頁碼
* @param pageNo
*/
public void setPageNo(int pageNo) {
this.pageNo = pageNo;
}
/**
* 獲取頁面大小
* @return
*/
public int getPageSize() {
return pageSize;
}
/**
* 設(shè)置頁面大小(最大500)
* @param pageSize
*/
public void setPageSize(int pageSize) {
this.pageSize = pageSize <= 0 ? 10 : pageSize;// > 500 ? 500 : pageSize;
}
/**
* 首頁索引
* @return
*/
@JsonIgnore
public int getFirst() {
return first;
}
/**
* 尾頁索引
* @return
*/
@JsonIgnore
public int getLast() {
return last;
}
/**
* 獲取頁面總數(shù)
* @return getLast();
*/
@JsonIgnore
public int getTotalPage() {
return getLast();
}
/**
* 是否為第一頁
* @return
*/
@JsonIgnore
public boolean isFirstPage() {
return firstPage;
}
/**
* 是否為最后一頁
* @return
*/
@JsonIgnore
public boolean isLastPage() {
return lastPage;
}
/**
* 上一頁索引值
* @return
*/
@JsonIgnore
public int getPrev() {
if (isFirstPage()) {
return pageNo;
} else {
return pageNo - 1;
}
}
/**
* 下一頁索引值
* @return
*/
@JsonIgnore
public int getNext() {
if (isLastPage()) {
return pageNo;
} else {
return pageNo + 1;
}
}
/**
* 獲取本頁數(shù)據(jù)對象列表
* @return List<T>
*/
public List<T> getList() {
return list;
}
/**
* 設(shè)置本頁數(shù)據(jù)對象列表
* @param list
*/
public Page<T> setList(List<T> list) {
this.list = list;
initialize();
return this;
}
/**
* 獲取查詢排序字符串
* @return
*/
@JsonIgnore
public String getOrderBy() {
// SQL過濾,防止注入
String reg = "(?:')|(?:--)|(/\\*(?:.|[\\n\\r])*?\\*/)|"
+ "(\\b(select|update|and|or|delete|insert|trancate|char|into|substr|ascii|declare|exec|count|master|into|drop|execute)\\b)";
Pattern sqlPattern = Pattern.compile(reg, Pattern.CASE_INSENSITIVE);
if (sqlPattern.matcher(orderBy).find()) {
return "";
}
return orderBy;
}
/**
* 設(shè)置查詢排序,標(biāo)準(zhǔn)查詢有效, 實(shí)例: updatedate desc, name asc
*/
public void setOrderBy(String orderBy) {
this.orderBy = orderBy;
}
/**
* 獲取點(diǎn)擊頁碼調(diào)用的js函數(shù)名稱
* function ${page.funcName}(pageNo){location="${ctx}/list-${category.id}${urlSuffix}?pageNo="+i;}
* @return
*/
@JsonIgnore
public String getFuncName() {
return funcName;
}
/**
* 設(shè)置點(diǎn)擊頁碼調(diào)用的js函數(shù)名稱,默認(rèn)為page,在一頁有多個分頁對象時使用。
* @param funcName 默認(rèn)為page
*/
public void setFuncName(String funcName) {
this.funcName = funcName;
}
/**
* 獲取分頁函數(shù)的附加參數(shù)
* @return
*/
@JsonIgnore
public String getFuncParam() {
return funcParam;
}
/**
* 設(shè)置分頁函數(shù)的附加參數(shù)
* @return
*/
public void setFuncParam(String funcParam) {
this.funcParam = funcParam;
}
/**
* 設(shè)置提示消息,顯示在“共n條”之后
* @param message
*/
public void setMessage(String message) {
this.message = message;
}
/**
* 分頁是否有效
* @return this.pageSize==-1
*/
@JsonIgnore
public boolean isDisabled() {
return this.pageSize==-1;
}
/**
* 是否進(jìn)行總數(shù)統(tǒng)計
* @return this.count==-1
*/
@JsonIgnore
public boolean isNotCount() {
return this.count==-1;
}
/**
* 獲取 Hibernate FirstResult
*/
public int getFirstResult(){
int firstResult = (getPageNo() - 1) * getPageSize();
if (firstResult >= getCount()) {
firstResult = 0;
}
return firstResult;
}
/**
* 獲取 Hibernate MaxResults
*/
public int getMaxResults(){
return getPageSize();
}
}
?
?
?
// 封裝查詢對象
UserReportVo userReportVo = new UserReportVo();
userReportVo.setUid(uid);
// 封裝分頁對象
Page<UserReportVo> page = new Page<UserReportVo>(pageNo,pageSize);
userReportVo.setPage(page);
List<UserReportVo> uVo =userService.getAllUserReportByUid(userReportVo);
轉(zhuǎn)載于:https://www.cnblogs.com/hwgok/p/6683541.html
總結(jié)
- 上一篇: day36-hibernate检索和优化
- 下一篇: 用unsigned char 表示字节