新建表
DROP DATABASE IF EXISTS `wjcms`;
CREATE DATABASE `wjcms` /*!40100 DEFAULT CHARACTER SET gb2312 */;
USE `wjcms`;
#
# Table structure for table t_article
#
CREATE TABLE `t_article` (
  `a_id` int(11) NOT NULL auto_increment,
  `a_sort` int(11) NOT NULL default '0',
  `a_title` varchar(50) default NULL,
  `a_body` text,
  `a_author` varchar(11) default '',
  `a_hit` int(11) NOT NULL default '0',
  `c_id` int(11) default '0',
  `a_date` varchar(20) default NULL,
  PRIMARY KEY  (`a_id`)
) 
实体
public class articleVO {
    private int a_id;
    private int a_sort;
    private int a_hit;
    private int c_id;
    private String a_title;
    private String a_body;
    private String a_author;
    private String a_date;
    // getter setter
新建page.java
package page.dal;
public class page {
    private int totalRows; //总行数
    private int pageSize = 10; //每页显示的行数
    private int currentPage; //当前页号
    private int totalPages; //总页数
    private int startRow; //当前页在数据库中的起始行
    public page(int _totalRows) {
     totalRows = _totalRows;
     totalPages=totalRows/pageSize;
     int mod=totalRows%pageSize;
     if(mod>0){
       totalPages++;
     }
     currentPage = 1;
     startRow = 0;
   }
   public int getStartRow() {
     return startRow;
   }
   public int getTotalPages() {
     return totalPages;
   }
   public int getCurrentPage() {
     return currentPage;
   }
   public int getPageSize() {
     return pageSize;
   }
   public void setTotalRows(int totalRows) {
     this.totalRows = totalRows;
   }
   public void setStartRow(int startRow) {
     this.startRow = startRow;
   }
   public void setTotalPages(int totalPages) {
     this.totalPages = totalPages;
   }
   public void setCurrentPage(int currentPage) {
     this.currentPage = currentPage;
   }
   public void setPageSize(int pageSize) {
     this.pageSize = pageSize;
   }
   public int getTotalRows() {
     return totalRows;
   }
   public void first() {
     currentPage = 1;
     startRow = 0;
   }
   public void previous() {
     if (currentPage == 1) {
       return;
     }
     currentPage--;
     startRow = (currentPage - 1) * pageSize;
   }
   public void next() {
     if (currentPage < totalPages) {
       currentPage++;
     }
     startRow = (currentPage - 1) * pageSize;
   }
   public void last() {
     currentPage = totalPages;
     startRow = (currentPage - 1) * pageSize;
   }
   public void refresh(int _currentPage) {
     currentPage = _currentPage;
     if (currentPage > totalPages) {
       last();
     }
   }
 }
新建 pageHelp.java
package page.dal;
import javax.servlet.http.*;
public class PagerHelp {
    public static page getPager(HttpServletRequest httpServletRequest,int totalRows) {
     //定义pager对象,用于传到页面
     page pager = new page(totalRows);
     //从Request对象中获取当前页号
     String currentPage = httpServletRequest.getParameter("currentPage");
     //如果当前页号为空,表示为首次查询该页
     //如果不为空,则刷新page对象,输入当前页号等信息
     if (currentPage != null) {
       pager.refresh(Integer.parseInt(currentPage));
     }
     //获取当前执行的方法,首页,前一页,后一页,尾页。
     String pagerMethod = httpServletRequest.getParameter("pageMethod");
     if (pagerMethod != null) {
       if (pagerMethod.equals("first")) {
         pager.first();
       } else if (pagerMethod.equals("previous")) {
         pager.previous();
       } else if (pagerMethod.equals("next")) {
         pager.next();
       } else if (pagerMethod.equals("last")) {
         pager.last();
       }
     }
     return pager;
   }
}
新建 util.java
package page.dal;
import net.sf.hibernate.Query;
import net.sf.hibernate.cfg.Configuration;
import java.util.List;
import net.sf.hibernate.HibernateException;
import net.sf.hibernate.SessionFactory;
import net.sf.hibernate.Session;
import java.util.*;
public class util {
    public util() {
    }
     private Session ss=null;
    public Session getSession()
  {
      //  Configuration config=null;
      SessionFactory sessionFactory;
      try {
          Configuration cfg = new Configuration();
          sessionFactory = cfg.addClass(articleVO.class).
                           buildSessionFactory();
          // SessionFactory sessionFactory=config.buildSessionFactory();
          ss = sessionFactory.openSession();
          return ss;
      } catch (HibernateException ex) {
          System.out.print("getsession出错了。。" + ex.getMessage());
          return null;
      }
  }
  public int getCount()
  {
      String sql="select count(*) from articleVO" ;
      this.getSession();
    try {
     // ss.createQuery("select count(a)as cont from articleVO a ");
      int rows= ((Integer) ss.iterate(sql).next()).intValue();
      ss.flush();
      return rows;
    } catch (HibernateException ex) {
        System.out.print("ex::"+ex.getMessage());
        return 0;
    }
  }
  public Collection  getList(int pagesize,int currow) throws HibernateException {
      Collection vehicleList = null;
      this.getSession();
      Query q=ss.createQuery("from articleVO");
      q.setFirstResult(currow);
      q.setMaxResults(pagesize);
      vehicleList=q.list();
      ss.flush();
      return vehicleList;
  }
}
新建 struts  PageAction.java
package page.dal;
import org.apache.struts.action.ActionMapping;
import org.apache.struts.action.ActionForm;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.Action;
import page.dal.*;
import java.util.*;
import net.sf.hibernate.*;
public class pageAction extends Action {
    public ActionForward execute(ActionMapping mapping, ActionForm form,
                                 HttpServletRequest request,
                                 HttpServletResponse response) {
        Collection clInfos = null;//用于输出到页面的记录集合
        int totalRows;//记录总行数
        util dal=new util();
        totalRows=dal.getCount();
        System.out.print("总行数=="+totalRows);
        page p=PagerHelp.getPager(request,totalRows);
        try {
            clInfos = dal.getList(p.getPageSize(), p.getStartRow());
        } catch (HibernateException ex) {
            System.out.print("action里的错误="+ex.getMessage());
        }
        request.setAttribute("page",p);
        request.setAttribute("list",clInfos);
        return mapping.findForward("page");
        //pageForm pageForm = (pageForm) form;
      //  throw new java.lang.UnsupportedOperationException(
              //  "Method $execute() not yet implemented.");
    }
}
前台页面
<%@ taglib uri="/WEB-INF/struts-tiles.tld" prefix="tiles" %>
<%@ taglib uri="/WEB-INF/struts-nested.tld" prefix="nested" %>
<%@ taglib uri="/WEB-INF/struts-logic.tld" prefix="logic" %>
<%@ taglib uri="/WEB-INF/struts-bean.tld" prefix="bean" %>
<%@ taglib uri="/WEB-INF/struts-html.tld" prefix="html" %>
<%@ page contentType="text/html; charset=GBK" %>
<html:html>
<head>
<title>
page
</title>
</head>
<body>
<table align="center" border="2">
<tr>
<th>a_title</th>
<th>a_body</th>
<th>a_a_date</th>
<th>a_author</th>
</tr>
<logic:iterate id="listd" name="list">
<tr>
<td>
<bean:write name="listd" property="a_title"/>
</td>
<td>
<bean:write name="listd" property="a_author"/>
</td>
<td>
<bean:write name="listd" property="a_date"/>
</td>
<td>
<bean:write name="listd" property="a_date"/>
</td>
</tr>
</logic:iterate>
</table>
第<bean:write name="page" property="currentPage"/>页
共<bean:write name="page" property="totalPages" />页
<html:link action="/pageAction.do?pageMethod=first"
paramName="page" paramProperty="currentPage" paramId="currentPage">首页</html:link>
   <html:link action="/pageAction.do?pageMethod=previous"
paramName="page" paramProperty="currentPage" paramId="currentPage">上一页</html:link>
   <html:link action="/pageAction.do?pageMethod=next"
paramName="page" paramProperty="currentPage" paramId="currentPage">下一页</html:link>
   <html:link action="/pageAction.do?pageMethod=last"
paramName="page" paramProperty="currentPage" paramId="currentPage">尾页</html:link>
</body>
</html:html>
启动浏览 pageAction.do  运行OK。
****************************************************************************************
配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
    "-//Hibernate/Hibernate Mapping DTD 2.0//EN"
    "http://hibernate.sourceforge.net/hibernate-mapping-2.0.dtd">
<hibernate-mapping>
    <class name="page.dal.articleVO" table="t_article" >
    <id name="a_id" column="a_id" unsaved-value="0" >
      <generator class="native"/>
 </id>
     <property name="c_id"    column="c_id"/>
     <property name="a_title" column="a_title"/>
     <property name="a_sort"  column="a_sort"/>
     <property name="a_date"  column="a_date"/>
     <property name="a_body"  column="a_body"/>
     <property name="a_hit"   column="a_hit"/>
     <property name="a_author" column="a_author"/>
   
    
  </class>
</hibernate-mapping>
hibernate.dialect net.sf.hibernate.dialect.MySQLDialect
hibernate.connection.driver_class org.gjt.mm.mysql.Driver
hibernate.connection.url jdbc:mysql://localhost:3306/wjcms
hibernate.connection.username root
hibernate.connection.password 
hibernate.connection.pool_size 1
hibernate.proxool.pool_alias pool1
hibernate.show_sql true
hibernate.max_fetch_depth 1
hibernate.cache.use_query_cache true