jsp中进行翻页跳转

14 篇文章 0 订阅
5 篇文章 0 订阅


       JSP界面中,实现翻页。实现翻页的关键在于对于数据库的操纵,使用sql语句(以mysql为例):


String sql = "select * from product limit "+(pageNo*4-4)+",4";pageNo即为你的页数,如pageNo=1时,即查找数据表product中序列为0,1,2,3的记录,

pageNo=2,查找4,5,6,7的记录。

String sql1 = "select count(*) from product";查找product中所有记录总数。

在这里贴下对数据操纵代码:

1.pageServlet

package tdw.controller;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;
import tdw.beans.*;
import tdw.dao.PageImple;

public class pageServlet extends HttpServlet {

	public void doGet(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {
		
		HttpSession session = request.getSession();
		int count = 0;
		
		int pageNo = 1;
		try{
		pageNo = Integer.parseInt(request.getParameter("pageNo"));
		}catch(Exception e){}
		
		if(pageNo<1){
			pageNo = 1;
		}
		
		session.setAttribute("pageNo", pageNo);
		
		List<Product> list = new ArrayList<Product>();
		
		PageImple pageImple = new PageImple();
		list = pageImple.page(pageNo);
		count = pageImple.getCount();
		
		session.setAttribute("pageList", list);
		session.setAttribute("count", count);
		response.sendRedirect("/SecondaryMarket/page.jsp");
	}

	public void doPost(HttpServletRequest request, HttpServletResponse response)
			throws ServletException, IOException {

		doGet(request, response);
	}

}

2.PageImple:

package tdw.dao;

import java.sql.DriverManager;
import java.sql.ResultSet;
import java.util.ArrayList;

import tdw.beans.Product;

import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;

public class PageImple {
	
	Statement st = null;
	Statement st1 = null;
	int count = 0;
	ArrayList<Product> list = new ArrayList<Product>();
	public ArrayList<Product> page(int pageNo){
		
		Connection conn = null;
		
		try {
			list = new ArrayList<Product>();
			Class.forName("com.mysql.jdbc.Driver").newInstance();
			conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/xxx", "xxx", "xxx");//更改自己的密码
			
			st = (Statement) conn.createStatement();
			
			String sql = "select * from product limit "+(pageNo*4-4)+",4";
			
                        ResultSet rs = st.executeQuery(sql);
			
			while(rs.next()){
				Product product = null;
				product = new Product();
				
				int pID = rs.getInt("pID");
				product.setpID(pID);
				
				float pprice = rs.getFloat("pprice");
				product.setPprice(pprice);
				
				String pinstrution = rs.getString("pinstrution");
				product.setPinstrution(pinstrution);
				
				String pusername = rs.getString("pusername");
				product.setPusername(pusername);
				
				
				String imagepath = rs.getString("imagepath");
				product.setImagepath(imagepath);
				
				int edornot = rs.getInt("edornot");
				product.setEdornot(edornot);
				
				String pname = rs.getString("pname");
				product.setPname(pname);
				
				String pcatagory = rs.getString("pcatagory");
				product.setPcatagory(pcatagory);
				
				list.add(product);
			}
		}catch(Exception e){}
		return list;
	}
	
	public int getCount(){
        
		Connection conn = null;
		
		try {
			Class.forName("com.mysql.jdbc.Driver").newInstance();
			conn = (Connection) DriverManager.getConnection("jdbc:mysql://localhost:3306/tdw", "root", "123");
			
			st = (Statement) conn.createStatement();
		
            String sql = "select count(*) from product";
		
		    ResultSet rs = st.executeQuery(sql);
		    while(rs.next()){
			  count = rs.getInt(1);
		    }
	}catch(Exception e){}
		return count;
}
}

3.product类

package tdw.beans;

public class Product {

	private int pID;
	private String pcatagory;
	private float pprice;
	private String pinstrution;
	private String pusername;
	private String imagepath;
	private int edornot;
	private String pname;
	private int pnum;
	
	
	
	
	public int getPnum() {
		return pnum;
	}
	public void setPnum(int pnum) {
		this.pnum = pnum;
	}
	public String getPusername() {
		return pusername;
	}
	public void setPusername(String pusername) {
		this.pusername = pusername;
	}
	public float getPprice() {
		return pprice;
	}
	public void setPprice(float pprice) {
		this.pprice = pprice;
	}
	public String getPname() {
		return pname;
	}
	public void setPname(String pname) {
		this.pname = pname;
	}
	public int getpID() {
		return pID;
	}
	public void setpID(int pID) {
		this.pID = pID;
	}
	public String getPcatagory() {
		return pcatagory;
	}
	public void setPcatagory(String pcatagory) {
		this.pcatagory = pcatagory;
	}
	public String getPinstrution() {
		return pinstrution;
	}
	public void setPinstrution(String pinstrution) {
		this.pinstrution = pinstrution;
	}
	public String getImagepath() {
		return imagepath;
	}
	public void setImagepath(String imagepath) {
		this.imagepath = imagepath;
	}
	public int getEdornot() {
		return edornot;
	}
	public void setEdornot(int edornot) {
		this.edornot = edornot;
	}
}

4.page.jsp

<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@ page language="java" import="tdw.beans.*" %>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    
    <title>page.jsp' starting page</title>

  </head>
  
  <body>b<br>
    
    
    <%
     List<Product> pageList = (List)session.getAttribute("pageList");
     int count = (Integer)session.getAttribute("count");
     
     int pageNo = (Integer)session.getAttribute("pageNo");
     
     int pageCount = count/4+1;//共分成多少页
     for(Product product:pageList) {%>
     <table>
       <tr>
       <td><%=product.getPname()%></td>
       </tr>
       <%} %>
     </table>
     <%if(pageNo==1){
     %>    
     <span>[第一页]</span>
     <span>[上一页]</span>
     <%
     }else{
     %>
     <span><a href="${pageContext.request.contextPath}/servlet/pageServlet?pageNo=1">[第一页]</a></span>
     <span><a href="<span style="font-family: Arial, Helvetica, sans-serif;">${pageContext.request.contextPath}</span>?pageNo=<%=pageNo-1%>">[上一页]</a></span>
     <% 
     }
      %>
      
      <%
      for(int i=1;i<=pageCount;i++){
          if(pageNo==i){
        %>
        <span><%=i %></span>
        <%  
          }else{
          %>
          <span><a href="${pageContext.request.contextPath}?pageNo=<%=i%>"></a><%=i %></span>
          <%
          }
      }
       %>
       <%
       if(pageNo==pageCount){
          %>
          <span>[下一页]</span>
          <span>[最后一页]</span>
          <%
       }else{
       %>
       <span><a href="${pageContext.request.contextPath}?pageNo=<%=pageNo+1%>">[下一页]</a></span>
       <span><a href="${pageContext.request.contextPath}?pageNo=<%=pageCount%>">[最后一页]</a></span>
       <%
       }
        %>
       
       <form action="${pageContext.request.contextPath }/servlet/pageServlet" method="post">
         <select name="pageNo">
         <%
         for(int i=1;i<=pageCount;i++){
          %>
         <option value="<%=i%>" ><%=i %></option>
         <%} %>
         </select>
         <input type="submit" value="go"></input>
       </form>
  </body>
</html>



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
本功能是以读书管理为例子而实现的翻页功能,目的希望大家很够很容易掌握它,同时将它学会。希望能给大家带来方便! Web应用开发的JavaServer Pages技术方法 在开发JSP规范的过程,太阳微系统公司(Sun Microsystems Inc.)与许许多多主要的Web服务器、应用服务器和开发工具供应商,以及各种各样富有经验的开发团体进行合作。其结果是找到了一种为应用和页面开发人员平衡了可移植性和易用性的开发方法。 JSP技术在多个方面加速了动态Web页面的开发: 将内容的生成和显示进行分离 使用JSP技术,Web页面开发人员可以使用HTML或者XML标识来设计和格式化最终页面。使用JSP标识或者小脚本来生成页面上的动态内容(内容是根据请求来变化的,例如请求帐户信息或者特定的一瓶酒的价格)。生成内容的逻辑被封装在标识和JavaBeans组件,并且捆绑在小脚本,所有的脚本在服务器端运行。如果核心逻辑被封装在标识和Beans,那么其他人,如Web管理人员和页面设计者,能够编辑和使用JSP页面,而不影响内容的生成。 在服务器端,JSP引擎解释JSP标识和小脚本,生成所请求的内容(例如,通过访问JavaBeans组件,使用JDBCTM技术访问数据库,或者包含文件),并且将结果以HTML(或者XML)页面的形式发送回浏览器。这有助于作者保护自己的代码,而又保证任何基于HTML的Web浏览器的完全可用性。 强调可重用的组件 绝大多数JSP页面依赖于可重用的,跨平台的组件(JavaBeans或者Enterprise JavaBeansTM组件)来执行应用程序所要求的更为复杂的处理。开发人员能够共享和交换执行普通操作的组件,或者使得这些组件为更多的使用者或者客户团体所使用。基于组件的方法加速了总体开发过程,并且使得各种组织在他们现有的技能和优化结果的开发努力得到平衡。 采用标识简化页面开发 Web页面开发人员不会都是熟悉脚本语言的编程人员。JavaServer Page技术封装了许多功能,这些功能是在易用的、与JSP相关的XML标识进行动态内容生成所需要的。标准的JSP标识能够访问和实例化JavaBeans组件,设置或者检索组件属性,下载Applet,以及执行用其他方法更难于编码和耗时的功能。 通过开发定制化标识库,JSP技术是可以扩展的。今后,第三方开发人员和其他人员可以为常用功能创建自己的标识库。这使得Web页面开发人员能够使用熟悉的工具和如同标识一样的执行特定功能的构件来工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值