分页显示 (SSH实现+Ajax读取json)

数据分页显示(SSH实现+Ajax读取json)


1.bean类:pageInfo.java
package com.org.momo.bean;

public class PageInfo {
     private Integer pageRows ;    //每页行数
     private Integer currentPage ; //当前页数
     private Integer pageTotal ;   //页面总数
     
     
	public Integer getPageRows() {
		return pageRows;
	}
	public void setPageRows(Integer pageRows) {
		this.pageRows = pageRows;
	}
	public Integer getCurrentPage() {
		return currentPage;
	}
	public void setCurrentPage(Integer currentPage) {
		this.currentPage = currentPage;
	}
	public Integer getPageTotal() {
		return pageTotal;
	}
	public void setPageTotal(Integer pageTotal) {
		this.pageTotal = pageTotal;
	}
   
}




2.dao接口:
package com.org.momo.dao;

import java.util.List;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;

public interface TeamDao {
    public void insert(Team team) throws Exception ;
    public void deleteById(Integer id) throws Exception ;
    public Team findById(Integer id) throws Exception ;
    public List<Team> findAll() throws Exception ;
    public void update(Team team) throws Exception ;
    public List<Team> findAllPage(PageInfo pageInfo) throws Exception ;
}





3.dao接口实现类,有两种实现底层数据查询: 
  a.Hibernate自身实现 
   b.spring对Hibernate的支持HibernateTemplate实现

a.Hibernate自身实现:
package com.org.momo.dao.hibernateTemplate;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;
import com.org.momo.dao.TeamDao;
import com.org.momo.util.HibernateUtil;
/**
 *   此方法为Hibernate自身的类实现底层数据访问
 *   另外一种实现方式就是:spring对Hibernate的支持HibernateTemplate(见下一个
 *   类 TeamDaoHibernateTemplate.java
 *   )
 * */

public class TeamDaoHibernate implements TeamDao {
	private SessionFactory sessionFactory;
	
	public TeamDaoHibernate() {
		sessionFactory = HibernateUtil.getSessionFactory();
	}

	public void insert(Team team) throws Exception {
		Session session = sessionFactory.openSession();
		
		Transaction transaction = session.beginTransaction();
		session.save(team);
		transaction.commit();
		
		session.close() ;
	}

	public void deleteById(Integer id) throws Exception {
		Session session = sessionFactory.openSession();
		Transaction transaction = session.beginTransaction();
		
		String hql = "delete from Team where id=?";
		Query query = session.createQuery(hql);
		query.setInteger(0, id);
		query.executeUpdate();
		
		transaction.commit();
		session.close();
	}

	public void update(Team team) throws Exception {
		Session session = sessionFactory.openSession();
		Transaction transaction = session.beginTransaction();
		
		session.merge(team);
		
		transaction.commit();
		session.close();
	}

	public List<Team> findAll() throws Exception {
		List<Team> teams = null;
		
		Session session = sessionFactory.openSession();
		
		Query query = session.createQuery("from Team");
		teams = query.list();
		
		session.close();
		
		return teams;
	}

	public Team findById(Integer id) throws Exception {
		Team team = null;
		
		Session session = sessionFactory.openSession();
		Query query = session.createQuery("from Team where id=?");
		query.setInteger(0, id);
		team = (Team)query.uniqueResult();
		session.close();
		
		return team;
	}

	public List<Team> findAllPage(PageInfo pageInfo) throws Exception {
		List<Team> teams = null;
		
		Session session = sessionFactory.openSession();
		
		Query queryTotal = session.createQuery("select count(id) from Team");
		int rowCount = ((Long)queryTotal.uniqueResult()).intValue() ;  //先转换为Long 在转换为int
		int pageTotal = rowCount/pageInfo.getPageRows();
		if(rowCount%pageInfo.getPageRows() > 0) {
			pageTotal++;
		}
		pageInfo.setPageTotal(pageTotal);
		
		Query query = session.createQuery("from Team");
		query.setFirstResult(pageInfo.getPageRows()*(pageInfo.getCurrentPage()-1));
		query.setMaxResults(pageInfo.getPageRows());
		teams = query.list();
		
		session.close();
		
		return teams;
	}

}



package com.org.momo.util;

import org.hibernate.SessionFactory;
import org.hibernate.cfg.AnnotationConfiguration;


public class HibernateUtil {
	  private static final SessionFactory sessionFactory;
      static{
    	  try{
    		  //初始化hibernate.cfg.xml配置,建立数据库连接
    		  sessionFactory = new AnnotationConfiguration().configure().buildSessionFactory();
    	  }catch(Exception e){
    		  e.printStackTrace() ;
    		  throw new ExceptionInInitializerError(e) ;
    	  }
      }
      
      public static SessionFactory getSessionFactory(){
    	  return sessionFactory ;
      }
}


[color=brown]applicationContext.xml文件配置映射:
<bean id="teamDao" class="com.org.momo.dao.hibernateTemplate.TeamDaoHibernate"></bean>[/color]


b.spring对Hibernate的支持HibernateTemplate实现:
package com.org.momo.dao.hibernateTemplate;

import java.sql.SQLException;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;
import com.org.momo.dao.TeamDao;

public class TeamDaoHibernateTemplate extends HibernateDaoSupport implements TeamDao {

	public void deleteById(Integer id) throws Exception {
        Team team = this.getHibernateTemplate().load(Team.class, id) ;
		this.getHibernateTemplate().delete(team) ;
	}

	public List<Team> findAll() throws Exception {
		return this.getHibernateTemplate().loadAll(Team.class);
	}

	public Team findById(Integer id) throws Exception {
		List<Team> teams = this.getHibernateTemplate().find("from Team where id=?",id) ;
		if(!teams.isEmpty()){
			return teams.get(0) ;
		}else{
		return null;
		}
	}

	public void insert(Team team) throws Exception {
		this.getHibernateTemplate().save(team) ;
	}

	public void update(Team team) throws Exception {
		this.getHibernateTemplate().update(team);
	}

	public List<Team> findAllPage(final PageInfo pageInfo) throws Exception {
		List<Team> teams = null;
		
		int rowTotal = ((Long)this.getHibernateTemplate().find("select count(id) from Team").get(0)).intValue();
		int pageTotal = rowTotal/pageInfo.getPageRows();
		if(rowTotal%pageInfo.getPageRows() > 0) {
			pageTotal++;
		}
		pageInfo.setPageTotal(pageTotal);
		
		teams = this.getHibernateTemplate().executeFind(new HibernateCallback(){
			public Object doInHibernate(Session session)
					throws HibernateException, SQLException {
				Query query = session.createQuery("from Team");
				query.setFirstResult(pageInfo.getPageRows()*(pageInfo.getCurrentPage()-1));
				query.setMaxResults(pageInfo.getPageRows());
				return query.list();
			}
			
		});
		
		return teams;
	}

}



spring的配置文件applicationContext.xml:
<?xml version="1.0" encoding="UTF-8"?>
<beans
xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.5.xsd">

	<bean id="teamService" class="com.org.momo.service.impl.TeamServiceImpl">
		<property name="teamDao" ref="teamDao"></property>
	</bean>
	<bean id="adminService" class="com.org.momo.service.impl.AdminServiceImpl">
		<property name="adminDao" ref="adminDao"></property>
	</bean>
    <bean id="logService" class="com.org.momo.service.impl.LogServiceImpl">
        <property name="logDao" ref="logDao"></property>
    </bean>
    <bean id="studentService" class="com.org.momo.service.impl.StudentServiceImpl">
        <property name="studentDao" ref="studentDao"></property>
    </bean>
    
    [color=brown]<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
		<property name="configLocation" value="classpath:hibernate.cfg.xml"/>
	</bean>
	<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
		<property name="sessionFactory" ref="sessionFactory"/>
	</bean>
    
    
    <bean id="teamDao" class="com.org.momo.dao.hibernateTemplate.TeamDaoHibernateTemplate">
		<property name="hibernateTemplate" ref="hibernateTemplate"/>
	</bean>[/color]    <bean id="adminDao" class="com.org.momo.dao.hibernateTemplate.AdminDaoHibernateTemplate">
        <property name="hibernateTemplate" ref="hibernateTemplate"/>
    </bean>
    <bean id="logDao" class="com.org.momo.dao.hibernateTemplate.LogDaoHibernateTemplate">
        <property name="hibernateTemplate" ref="hibernateTemplate"/>
    </bean>
    <bean id="studentDao" class="com.org.momo.dao.hibernateTemplate.StudentDaoHibernateTemplate">
        <property name="hibernateTemplate" ref="hibernateTemplate"/>
    </bean>
    

    <bean class="org.springframework.context.annotation.CommonAnnotationBeanPostProcessor">
    </bean>
</beans>


4.业务层:service接口和接口实现类serviceImpl:
package com.org.momo.service;

import java.util.List;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;
import com.org.momo.dao.TeamDao;

public interface TeamService {
   public TeamDao getTeamDao() ;
   public void setTeamDao(TeamDao teamDao) ;
   public void addTeam(Team team) throws Exception ;
   public void deleteTeam(Integer id) throws Exception ;
   public Team getTeam(Integer id) throws Exception ;
   public List<Team> getTeams() throws Exception ;
   public void updateTeam(Team team) throws Exception ;
   public List<Team> pageTeams(PageInfo page) throws Exception ;
}


package com.org.momo.service.impl;

import java.util.List;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;
import com.org.momo.dao.TeamDao;
import com.org.momo.service.TeamService;

public class TeamServiceImpl implements TeamService {
    private TeamDao teamDao ;
	
	public void addTeam(Team team) throws Exception {
       teamDao.insert(team) ;
	}

	public void deleteTeam(Integer id) throws Exception {
       teamDao.deleteById(id) ;
	}

	public Team getTeam(Integer id) throws Exception {
		return teamDao.findById(id) ;
	}

	public TeamDao getTeamDao() {
		return teamDao;
	}

	public List<Team> getTeams() throws Exception {
		return teamDao.findAll() ;
	}

	public void setTeamDao(TeamDao teamDao) {
        this.teamDao = teamDao ;
	}

	public void updateTeam(Team team) throws Exception {
        teamDao.update(team) ;
	}

	public List<Team> pageTeams(PageInfo page) throws Exception {
		return teamDao.findAllPage(page) ;
	}

}




5.控制层Action类:
package com.org.momo.action.team;

import java.io.PrintWriter;
import java.util.List;

import javax.annotation.Resource;
import javax.servlet.http.HttpServletResponse;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionSupport;
import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Team;
import com.org.momo.service.TeamService;
import com.org.momo.util.JsonUtil;
import com.org.momo.util.XmlUtil;

public class ViewTeamsJSONAction extends ActionSupport {
	@Resource
	private TeamService teamService;
	private PageInfo pageInfo ;
	
	public PageInfo getPageInfo() {
		return pageInfo;
	}

	public void setPageInfo(PageInfo pageInfo) {
		this.pageInfo = pageInfo;
	}

	public String execute() {
		HttpServletResponse response = ServletActionContext.getResponse();
		response.setContentType("text/plain;charset=GBK");
		try {
			PrintWriter out = response.getWriter();
			
			//设置每页显示多少行
			pageInfo.setPageRows(5) ;
			//获取所有小组
			List<Team> teams = teamService.pageTeams(pageInfo) ;
			out.println(JsonUtil.teamsToJsonPage(teams, pageInfo));  //将document转换为String输出
			out.flush() ;
			out.close() ;
		} catch (Exception e) {
			e.printStackTrace() ;
		}
		
		return NONE;
	}
}



6.struts2的配置文件struts.xml
   <?xml version="1.0" encoding="GBK"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.0 //EN"
  "struts-2.1.7.dtd">
<struts>
<constant name="struts.i18n.encoding" value="GBK"></constant>

<package name="team" namespace="/team" extends="struts-default">
    <interceptors>
        <interceptor name="LogInterceptor" class="com.org.momo.interceptor.LogInterceptor"></interceptor>
        <interceptor-stack name="TeamInterceptor">
          <interceptor-ref name="defaultStack"></interceptor-ref>
          <interceptor-ref name="LogInterceptor"></interceptor-ref>
        </interceptor-stack>
    </interceptors> 
        <default-interceptor-ref name="TeamInterceptor"></default-interceptor-ref>

    <action name="TeamNameCheck" class="com.org.momo.action.team.TeamNameCheckAction">
	</action>
	<action name="ViewTeamsXML" class="com.org.momo.action.team.ViewTeamsXMLAction">
	</action>
	<action name="ViewTeamsXSL" class="com.org.momo.action.team.ViewTeamsXSLAction">
	</action>
	[color=red]<action name="ViewTeamsJSON" class="com.org.momo.action.team.ViewTeamsJSONAction">
	</action>[/color]	<action name="ViewTeams" class="com.org.momo.action.team.ViewTeamsAction">
		<result name="success">/team/viewTeams.jsp</result>
		<result name="error">/team/exception.jsp</result>
	</action>
	<action name="DeleteTeam" class="com.org.momo.action.team.DeleteTeamAction">
		<result name="success" type="redirect">/team/ViewTeams</result>
		<result name="error">/team/exception.jsp</result>
	</action>
	<action name="ViewUpdateTeam" class="com.org.momo.action.team.UpdateTeamViewAction">
		<result name="success">/team/updateTeam.jsp</result>
		<result name="error">/team/exception.jsp</result>
	</action>
	<action name="UpdateTeam" class="com.org.momo.action.team.UpdateTeamAction">
		<result name="success" type="redirect">/team/ViewTeams</result>
		<result name="error">/team/exception.jsp</result>
	</action>
	<action name="AddTeam" class="com.org.momo.action.team.AddTeamAction">
		<result name="success" type="redirect">/team/ViewTeams</result>
		<result name="error">/team/exception.jsp</result>
		<result name="input">/team/addTeam.jsp</result>
	</action>
</package>


<package name="admin" namespace="/admin" extends="struts-default">
    <interceptors>
        <interceptor name="LogInterceptor" class="com.org.momo.interceptor.LogInterceptor"></interceptor>
        <interceptor-stack name="TeamInterceptor">
          <interceptor-ref name="defaultStack"></interceptor-ref>
          <interceptor-ref name="LogInterceptor"></interceptor-ref>
        </interceptor-stack>
    </interceptors> 
        <default-interceptor-ref name="TeamInterceptor"></default-interceptor-ref>
        
    <action name="Login" class="com.org.momo.action.admin.LoginAction">
        <result name="success">/index.jsp</result>
        <result name="input">/login.jsp</result>
        <result name="error">/team/exception.jsp</result>
    </action>
    <action name="UpdatePassword" class="com.org.momo.action.admin.UpdatePasswordAction">
        <result name="success">/team/index.jsp</result>
        <result name="error">/team/exception.jsp</result>
    </action>
</package>

<package name="student" namespace="/student" extends="struts-default">
   <interceptors>
        <interceptor name="LogInterceptor" class="com.org.momo.interceptor.LogInterceptor"></interceptor>
        <interceptor-stack name="TeamInterceptor">
          <interceptor-ref name="defaultStack"></interceptor-ref>
          <interceptor-ref name="LogInterceptor"></interceptor-ref>
        </interceptor-stack>
    </interceptors> 
        <default-interceptor-ref name="TeamInterceptor"></default-interceptor-ref>

    <action name="AddStudent" class="com.org.momo.action.student.AddStudentAction">
        <result name="success" type="redirect">/student/ViewStudents</result>
        <result name="error">/student/exception.jsp</result>
    </action>
    <action name="ViewStudents" class="com.org.momo.action.student.ViewStudentsAction">
        <result name="success">/student/viewStudent.jsp</result>
        <result name="error">/student/exception.jsp</result>
    </action>
    <action name="DeleteStudent" class="com.org.momo.action.student.DeleteStudentAction">
        <result name="success" type="redirect">/student/ViewStudents</result>
        <result name="error">/student/exception.jsp</result>
    </action>
    <action name="ViewUpdateStudent" class="com.org.momo.action.student.ViewUpdateStudentAction">
        <result name="success">/student/updateStudent.jsp</result>
        <result name="error">/student/exception.jsp</result>
    </action>
    <action name="UpdateStudent" class="com.org.momo.action.student.UpdateStudentAction">
        <result name="success" type="redirect">/student/ViewStudents</result>
        <result name="error">/student/exception.jsp</result>
    </action>
</package>
</struts>



7.JSONUtil处理类:

package com.org.momo.util;

import java.util.List;

import com.org.momo.bean.PageInfo;
import com.org.momo.bean.Student;
import com.org.momo.bean.Team;

public class JsonUtil {

	public static String teamsToJsonPage(List<Team> teams,PageInfo pageInfo)throws Exception
	{
		String jsonStr = null;
		StringBuffer strBuffer = new StringBuffer();
		strBuffer.append("{");
		//处理teams
		//teams开始
		strBuffer.append("\"teams\":[");
		//处理teams
		for(int i=0;i<teams.size();i++)
		{
			Team team = teams.get(i); 
			//team开始
			strBuffer.append("{");
			//处理id
			strBuffer.append("\"id\":");
			strBuffer.append(team.getId());
			strBuffer.append(",");
			//处理name
			strBuffer.append("\"name\":\"");
			strBuffer.append(team.getName());
			strBuffer.append("\",");
			//处理leader
			strBuffer.append("\"leader\":\"");
			strBuffer.append(team.getLeader());
			strBuffer.append("\",");
			//处理slogan
			strBuffer.append("\"slogan\":\"");
			strBuffer.append(team.getSlogan());	
			strBuffer.append("\",");
			//处理members
			strBuffer.append("\"members\":\"") ;
			if(team.getMembers()!=null){
				int j=0 ;
				for(Student stu:team.getMembers()){
					j++ ;
					strBuffer.append(stu.getName()) ;
					if(j<team.getMembers().size()){
						strBuffer.append(",") ;
					}
				}
			}
			strBuffer.append("\"") ;
			
			//team结束
			if(i<teams.size()-1)
			{
			strBuffer.append("},");
			}
			else
			{
				strBuffer.append("}");
			}
			
		}
		
		//teams结束
		strBuffer.append("],");
		
		//pageInfo开始
		strBuffer.append("\"pageInfo\":{");
		//处理pageRows 
		strBuffer.append("\"pageRows\":");
		strBuffer.append(pageInfo.getPageRows());
		strBuffer.append(",");
		//处理currentPage
		strBuffer.append("\"currentPage\":");
		strBuffer.append(pageInfo.getCurrentPage());
		strBuffer.append(",");
		//处理pageTotal
		strBuffer.append("\"pageTotal\":");
		strBuffer.append(pageInfo.getPageTotal());
		
	
	    //pageInfo结束
		strBuffer.append("}");
		//json结束
		strBuffer.append("}");
		jsonStr = strBuffer.toString();
		return jsonStr;
	}
}



8.前台界面JSP+javascript+AJAX(读取保存了teamsinfo和pageInfo的JSON字符串)
  <%@ page language="java" contentType="text/html; charset=GBK" pageEncoding="GBK"%>
<%
String basePath = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort() + request.getContextPath() + "/";
%>
<html>
<head>
<base href="<%=basePath%>">
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<title>显示小组(Ajax)</title>
<link rel="stylesheet" type="text/css" href="css/team.css" />
<script type="text/javascript" src="js/trim.js"></script>
<script type="text/javascript">
function startRequest(pageNo) {
	createXMLHttpRequest();
	xmlHttp.onreadystatechange = function() {
		handleStateChange(pageNo);
	};
	xmlHttp.open("POST","team/ViewTeamsJSON",true);
	xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
	xmlHttp.send("pageInfo.currentPage=" + pageNo);
}

function handleStateChange(pageNo) {
	if(xmlHttp.readyState == 4) {
		if(xmlHttp.status == 200) {
		
			 var text = xmlHttp.responseText ;
			 var jsonObject = eval ("(" + text + ")");
			 var teamTable = document.getElementById("teamTable");
			 //alert(text) ;
			 
			  //清除原有数据
		   for(var i=teamTable.rows.length-1;i>0;i--){
		       teamTable.deleteRow(i) ;
		   }
			 
			 for(var i=0;i<jsonObject.teams.length;i++) {
			     //为表格加一行
				var tr = teamTable.insertRow(i+1);
			    
			    //为表格加一个格
				var td = tr.insertCell(0);
				td.innerHTML = jsonObject.teams[i].id;
				
				//为表格加一个格
				var td = tr.insertCell(1);
				td.innerHTML = jsonObject.teams[i].name;
				
				//为表格加一个格
				var td = tr.insertCell(2);
				td.innerHTML = jsonObject.teams[i].leader;
				
				//为表格加一个格
				var td = tr.insertCell(3);
				td.innerHTML = jsonObject.teams[i].slogan;
				
				//为表格加一个格
				var td = tr.insertCell(4);
				td.innerHTML = jsonObject.teams[i].members;
				
				//为表格加一个格
				var td = tr.insertCell(5);
				td.innerHTML = "<a href='team/ViewUpdateTeam?team.id="+jsonObject.teams[i].id+"'>修改</a>  <a href='team/DeleteTeam?team.id="+jsonObject.teams[i].id+"'>删除</a>";
			 }
			 
			 //处理页面跳转的连接
			var pageDiv = document.getElementById("page") ;
			var pageTotal = jsonObject.pageInfo.pageTotal ;
			var pageHtml =" ";
			if(pageNo>1){
			pageHtml += "<a href='javascript:startRequest("+ 1 +")'>首页</a>  " ;     //可以改为上一页   "1"  改为:   (pageNo-1)
			 } 
		    for(i = 0 ; i < pageTotal; i ++){
               pageHtml += "<a href = 'javascript:startRequest("+(i+1)+")'>"+(i+1)+"</a>   ";
              } 
			   
			 if(pageNo < pageTotal) {
				pageHtml += " <a href='javascript:startRequest(" + pageTotal + ")'>尾页</a>";    //可以改为下一页   pageTotal  改为:  (pageNo+1)
			   }
			pageDiv.innerHTML = pageHtml ;
		}
	}
}
</script>
</head>
<body onload="startRequest(1)">
<div id="top">
<h1>显示小组</h1>
</div>
<div id="content">
<table border="1" id="teamTable">
<tr>
<th>ID</th><th>组名</th><th>组长</th><th>口号</th><th>成员</th><th>操&nbsp;&nbsp;作</th>
</tr>
</table>
</div>
<p><div id="page"></div>
<p><a href="team/index.jsp">返回小组管理</a>
</body>
</html>

你可能感兴趣的:(分页显示 (SSH实现+Ajax读取json))