這次主要是講解一下通過登錄後對得到的數據進行分頁,首先我們新建一個登錄頁面login.jsp,因為我們主要學習一下分頁,所以登錄驗證的部分不再闡述,主要代碼如下:
1 <form action="pageServlet"> 2 用戶名:<input type="text" name="username"><br> 3 密 碼:<input type="text" name="password"><br> 4 <input type="submit" value="提交"> 5 </form>
首先建立實體類User.java並添加get和set方法:
1 public class User {
2 private String username;
3 private String password;
4 public String getUsername() {
5 return username;
6 }
7 public void setUsername(String username) {
8 this.username = username;
9 }
10 public String getPassword() {
11 return password;
12 }
13 public void setPassword(String password) {
14 this.password = password;
15 }
16
17 }
我們可以看到form表單是提交到pageServlet中,所以我們新建一個PageServlet,並在Servlet中獲取到數據,同時做一些分頁的准備,具體含義可以參照注釋理解,PageServlet代碼:
1 public class PageServlet extends HttpServlet {
2 public void doGet(HttpServletRequest request, HttpServletResponse response)
3 throws ServletException, IOException {
4 List<User> list = new ArrayList<User>();
5 // 在這裡我不再連接數據庫而是用虛擬的數據進行測試效果,小伙伴可以連接數據庫查詢到之後返回一個list
6 for (int i = 1; i < 7; i++) {
7 User user1 = new User();
8 user1.setUsername("第" + i + "個用戶名");
9 user1.setPassword("第" + i + "密碼");
10 list.add(user1);
11 }
12 HttpSession session = request.getSession();
13 // 將數據存到session中以便於在前台獲取
14 session.setAttribute("userList", list);
15 //獲取當前頁的頁數並轉為int類型,最終將數據存到session中
16 int pageNos;
17 if (request.getParameter("pageNos") == null
18 || Integer.parseInt(request.getParameter("pageNos")) < 1) {
19 pageNos = 1;
20 } else {
21 pageNos = Integer.parseInt(request.getParameter("pageNos"));
22 }
23 session.setAttribute("pageNos", pageNos);
24 // 定義總頁數並存到session中
25 int countPage = 3;
26 // 在實際開發中我們的總頁數可以根據sql語句得到查詢到的總條數,然後用總條數除每頁的條數得到總頁數
27 session.setAttribute("countPage", countPage);
28 request.getRequestDispatcher("index.jsp").forward(request, response);
29 }
30
31 public void doPost(HttpServletRequest request, HttpServletResponse response)
32 throws ServletException, IOException {
33
34 }
35
36 }
在上述代碼中我們最終將轉發到index.jsp頁面,此時我們所有的數據都將顯示在index.jsp中,用JSTL和EL表達式獲取得到,index.jsp主要代碼如下:
1 <body>
2 <c:forEach items="${userList}" var="user" begin="${(pageNos-1)*2 }"
3 end="${pageNos*2-1}">
4 <center>
5 <div>${user.username}</div>
6 </center>
7 <center>
8 <div>${user.password}</div>
9 </center>
10 </c:forEach>
11 <center>
12 <c:if test="${pageNos>1 }">
13 <a href="pageServlet?pageNos=1" >首頁</a>
14 <a href="pageServlet?pageNos=${pageNos-1 }">上一頁</a>
15 </c:if>
16 <c:if test="${pageNos <countPage }">
17 <a href="pageServlet?pageNos=${pageNos+1 }">下一頁</a>
18 <a href="pageServlet?pageNos=${countPage }">末頁</a>
19 </c:if>
20 </center>
21 <form action="pageServlet">
22 <h4 align="center">共${countPage}頁
23 <input type="text" value="${pageNos}" name="pageNos" size="1">頁
24 <input type="submit" value="go">
25 </h4>
26 </form>
27 </body>
第二行中我們用<c:forEach >對session.setAttribute();中的內容進行獲取。注意,這裡我默認是每頁兩條數據,所以是(pageNos-1)*2,如果每頁N條數據則需將2改為N,當然N也可以從後台Servlet中獲取得到。
同時,因為我們在index.jsp中用了JSTL表達式,所以記得要導入引用:
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
到這裡我們就完成了一個簡單的分頁,快去試試吧。