jsp总结


title: JSP

一、引言


1.1 现有问题

在之前学习Servlet时,服务端通过Servlet响应客户端页面,有什么不足之处?

  • 开发方式麻烦:继承父类、覆盖方法、配置Web.xml或注解
  • 代码修改麻烦:重新编译、部署、重启服务
  • 显示方式麻烦:获取流、使用println(“”);逐行打印
  • 协同开发麻烦:UI负责美化页面,程序员负责编写代码。UI不懂Java,程序员又不能将所有前端页面的内容通过流输出

二、JSP(Java Server Pages)


2.1 概念

简化的Servlet设计,在HTML标签中嵌套Java代码,用以高效开发Web应用的动态网页

设置JSP页面热更新

jsp总结_第1张图片

2.2 作用

替换显示页面部分的Servlet(使用*.jsp文件替换XxxJSP.java)

三、JSP开发【重点


3.1 创建JSP

在web目录下新建*.jsp文件(与WEB-INF平级)

3.1.1 JSP编写Java代码
<%@ page import="java.util.Date" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>


    我们的第一个jsp页面


第一个JSP页面

系统的当前时间是:<%= new Date()%>
  • 使用<%= %>标签编写Java代码在页面中打印当前系统时间
3.1.2 访问JSP

在浏览器输入http://ip:port/项目路径/资源名称

3.2 JSP与Servlet

  • 关系

    • JSP文件在容器中会转换成Servlet执行。
    • JSP是对Servlet的一种高级封装。本质还是Servlet。
  • 区别

    • 与 Servlet 相比:JSP可以很方便的编写或者修改HTML网页而不用去面对大量的println语句。
JSP与Servlet区别
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mj7lMVlc-1679828958808)(https://qfedu-1254123199.cos.ap-nanjing.myqcloud.com/img/JSP%E4%B8%8EServlet%E5%8C%BA%E5%88%AB.png)]

3.3 JSP实现原理

Tomcat会将xxx.jsp转换成Java代码,进而编译成.class文件运行,最终将运行结果通过response响应给客户端。

JSP实现原理
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-pmS3WZlp-1679828958808)(https://qfedu-1254123199.cos.ap-nanjing.myqcloud.com/img/JSP%E5%AE%9E%E7%8E%B0%E5%8E%9F%E7%90%86.png)]

jsp总结_第2张图片

3.3.1 JSP.java源文件存放目录

使用IDEA开发工具,Tomcat编译后的JSP文件(Xxx_jsp.class 和 Xxx_jsp.java)的存放地点:

  • C:\用户\账户名\.IntelliJIdea2019.1\system\tomcat\项目名称\work\Catalina\localhost\应用上下文\org\apache\jsp

四、JSP与HTML集成开发


4.1 脚本

脚本可以编写Java语句、变量、方法或表达式。

4.1.1 普通脚本

语法:<% Java代码 %>


Hello World

Hello World!
<% //jsp中,使用小脚本嵌入java代码! out.println("hi");//打印内容在客户端页面 System.out.println("hi");//打印内容在控制台 %>
  • 经验:普通脚本可以使用所有Java语法,除了定义函数。
  • 注意:脚本与脚本之间不可嵌套,脚本与HTML标签不可嵌套
4.1.2 声明脚本

语法:<%! 定义变量、函数 %>

<%! int i = 0; %> 
<%! int a, b, c; %> 
<%! Object object = new Object(); %> 
<%!
  //定义方法
  public void m1(){
 	 System.out.println("你好");
}
%>
  • 注意:声明脚本声明的变量是全局变量。
  • 声明脚本的内容必须在普通脚本<% %>中调用。
  • 如果声明脚本中的函数具有返回值,可以使用输出脚本调用<%= %>
4.1.3 输出脚本

语法:<%=Java表达式 %>

out.write(Java表达式);

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




jsp基本使用


今天的日期是: <%= new java.util.Date() %>

  • 经验:输出脚本可以输出带有返回值的函数
  • 注意:输出脚本中不能加 ;

4.2 JSP注释

JSP注释主要有两个作用:为脚本代码作注释以及HTML内容注释。

4.2.1 语法规则
语法 描述
<%-- 注释 --%> JSP注释,注释内容不会被发送至浏览器甚至不会被编译
< !-- 注释 – > HTML注释,通过浏览器查看网页源代码时可以看见注释内容
4.2.2 注释
<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>




jsp基础教程


<%-- JSP注释在网页中不会被显示--%> 

今天的日期是: <%= new java.util.Date() %>

4.3 JSP指令

JSP指令用来设置与整个JSP页面相关的属性。

指令 描述
<%@ page … %> 定义页面的依赖属性,比如脚本语言、error页面、缓存需求等等
<%@ include … %> 包含其他文件
<%@ taglib … %> 引入标签库的定义,可以是自定义标签

jsp总结_第3张图片

4.3.1 page指令
  • 语法:<%@ page attribute1=“value1” attribute2=“value2” %>

  • Page指令为容器提供当前页面的使用说明。一个JSP页面可以包含多个page指令。

属性 描述
contentType 指定当前JSP页面的MIME类型和字符编码格式
errorPage 指定当JSP页面发生异常时需要转向的错误处理页面
isErrorPage 指定当前页面是否可以作为另一个JSP页面的错误处理页面
import 导入要使用的Java类
language 定义JSP页面所用的脚本语言,默认是Java
session 指定JSP页面是否使用session。默认为true立即创建,false为使用时创建
pageEncoding 指定JSP页面的解码格式
4.3.2 include指令
  • 语法:<%@ include file = “被包含的JSP路径”%>

  • 通过include指令来包含其他文件。

  • 被包含的文件可以是JSP文件、HTML文件或文本文件。包含的文件就好像是当前JSP文件的一部分,会被同时编译执行(静态包含)。

<%@ include file="header.jsp"%>
...
...
<%@ include file="footer.jsp" %>
  • 注意:可能会有重名的冲突问题,不建议使用。
4.3.3 taglib指令
  • 语法:<%@ taglib uri=“外部标签库路径” prefix=“前缀” %>

  • 引入JSP的标准标签库

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

4.4 动作标签

  • 语法:
  • 动作标签指的是JSP页面在运行期间的命令
4.4.1 include
  • 语法:
  • 动作元素会将外部文件输出结果包含在JSP中(动态包含)。
属性 描述
page 包含在页面中的相对URL地址。

  • 注意:前面已经介绍过include指令,它是将外部文件的输出代码复制到了当前JSP文件中。而这里的jsp:include动作不同,是将外部文件的输出结果引入到了当前JSP文件中。
4.4.2 useBean
  • 语法:

  • jsp:useBean 动作用来加载一个将在JSP页面中使用的JavaBean。


User user = new User();
  • 在类载入后,我们可以通过 jsp:setProperty 和 jsp:getProperty 动作来修改和获取bean的属性。
4.4.3 setProperty

可以在jsp:useBean元素之后使用jsp:setProperty进行属性的赋值

属性 描述
name name属性是必需的。它表示要设置属性的是哪个Bean。
property property属性是必需的。它表示要设置哪个属性。
value value 属性是可选的。该属性用来指定Bean属性的值。



jsp总结_第4张图片

4.4.4 getProperty

jsp:getProperty动作提取指定Bean属性的值,转换成字符串,然后输出。

属性 描述
name 要检索的Bean属性名称。Bean必须已定义。
property 表示要提取Bean属性的值





4.4.5 forward
  • 语法:

  • jsp:forward动作把请求转到另外的页面。

属性 描述
page page属性包含的是一个相对URL。

4.4.6 param
  • 语法:

  • 在转发动作内部使用,做参数传递


         
         

4.5 内置对象

由JSP自动创建的对象,可以直接使用

对象名 类型 说明
request javax.servlet.http.HttpServletRequest
response javax.servlet.http.HttpServletResponse
session javax.servlet.http.HttpSession 由session=“true”开关
application javax.servlet.ServletContext
config javax.servlet.ServletConfig
exception java.lang.Throwable 由isErrorPage=“false”开关
out javax.servlet.jsp.JspWriter javax.servlet.jsp.JspWriter
pageContext javax.servlet.jsp.PageContext
page java.lang.Object当前对象this 当前servlet实例
4.5.1 四大域对象

域: 西域 西边的地方

JSP有四大作用域对象,存储数据和获取数据的方式一样,不同的是取值的范围有差别

  • pageContext (javax.servlet.jsp.PageContext) 当前JSP页面范围
  • request (javax.servlet.http.HttpServletRequest) 一次请求有效
  • session (javax.servlet.http.HttpSession) 一次会话有效(关闭浏览器失效)
  • application (javax.servlet.ServletContext) 整个Web应用有效(服务器重启或关闭失效)
4.5.2 pageContext 对象
  • pageContext对象是javax.servlet.jsp.PageContext 类的实例,拥有作用域,用来代表整个JSP页面。
  • 当前页面的作用域对象,一旦跳转则失效
  • 通过setAttribute(“name”,value);存储值
  • 通过getAttribute(“name”);获取值
  • 用于获取其他8个内置对象或者操作其他对象的作用域
<%
	pageContext.setAttribute("name",value);//当前页面作用域有效
%>
4.5.3 pageContext获取其他内置对象
<%
    pageContext.getRequest();//返回request内置对象 
    pageContext.getResponse();//返回response内置对象 
    pageContext.getServletConfig();//返回config内置对象
    pageContext.getException();//返回exception内置对象 
    pageContext.getPage();//返回page内置对象
    pageContext.getOut();//返回out内置对象
    pageContext.getServletContext();//返回application内置对象
    pageContext.getSession();//返回session内置对象 
%>
4.5.4 pageContext操作其他内置对象的作用域

pageContext对象可以操作其他作用域存储和获取。

<%
	//操作其他作用域存储
	pageContext.setAttribute("name",value);//当前页面有效
	pageContext.setAttribute("name",value,PageContext.REQUEST_SCOPE);//request作用域
	request.setAttribute("name",value); //跟上面的等效
	pageContext.setAttribute("name",value,PageContext.SESSION_SCOPE);//session作用域
	pageContext.setAttribute("name",value,PageContext.APPLICATION_SCOPE);//application作用域
%>

<%
	//操作其他作用域获取
    pageContext.getAttribute("name");//当前页面作用域
    pageContext.getAttribute("name",PageContext.REQUEST_SCOPE);//request作用域
    pageContext.getAttribute("name",PageContext.SESSION_SCOPE);//session作用域
    pageContext.getAttribute("name",PageContext.APPLICATION_SCOPE);//application作用域
    pageContext.findAttribute("name");//从pageContext,request ,session ,application依次查找
%>

五、EL表达式(Expression Language)

表达式语言

${作用域.key}


5.1 概念

EL使JSP写起来更简单、简洁。主要用于获取作用域中的数据

5.2 作用

用于替换作用域对象.getAttribute(“name”);

request.setAttribute(“name”,“tom”); //放数据

request.getAttribute(“name”) -> ${requestScope.name}

5.3 EL的应用(获取基本类型、字符串)

  • ${scope.name} 获取具体某个作用域中的数据
  • ${name} 获取作用域中的数据,逐级查找(pageContext、request、session、application) 从小范围到大范围
5.3.1 EL应用案例
<%
	//存储在request作用域
	request.setAttribute("name","tom");
    request.setAttribute("age",18);
%>
${requestScope.name} <%--获取request作用域中name对应的值,找到就返回,没找到返回""  --%>
${name}<%--从最小作用域逐级查找name对应的值,找到就返回,没找到返回"" --%>
5.3.2 EL和JSP脚本的区别
  • <%=request.getAttribute() %> 没有找到返回null

  • ${requestScope.name} 没找到返回""

5.4 EL的应用(获取引用类型)

使用EL获取作用域中的对象调用属性时,只能访问对象的get方法,必须遵守命名规范定义

<%
    Emp e = new Emp();
    e.setName("gavin");
    e.setAge(19);
    request.setAttribute("e",e);
%>
${requestScope.e.name}<%-- 调用getName()方法 --%>

5.5 EL的应用(获取数组、集合的元素)

EL可以获取Array、List、Map中的元素,Set由于没下标,无法直接访问元素,后续可遍历

<%@ page import="com.example.jsp.entity.User" %>
<%@ page import="com.example.jsp.entity.Emp" %>
<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page import="java.util.Map" %>
<%@ page import="java.util.HashMap" %>
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>


    EL表达式2


<%
    User user = new User();
    user.setName("张三");
    user.setAge(18);
    request.setAttribute("user",user);
%>

EL表达式取数据

${requestScope.user} ${requestScope.user.name} ${requestScope.user.age}

演示数组

<% String fruit = "香蕉"; out.write("换行
"); out.write(fruit+"
"); out.write("第二行"); int[] array = new int[]{1,2,3,4,5}; request.setAttribute("array",array); List emps = new ArrayList<>(); emps.add(new Emp(1,"大壮",2000,19)); emps.add(new Emp(2,"阳阳",3000,29)); emps.add(new Emp(3,"四宇",4000,39)); request.setAttribute("emps",emps); Map maps = new HashMap<>(); maps.put("CN","中国"); maps.put("FK","法国"); maps.put("US","美国"); request.setAttribute("maps",maps); %> ${requestScope.array[0]}
${requestScope.array[1]}
<%--获取数组长度的操作不支持--%> <%--EL如何取得数组长度?EL取不了要靠JSTL--%> ${requestScope.array} ${requestScope.emps[0]}
${requestScope.emps.get(0)}
<%--获取集合list的长度--%> ${requestScope.emps.size()}
${requestScope.maps}
${requestScope.maps["CN"]}
${requestScope.maps.CN}

5.6 EL的运算符

操作符 描述
. 访问一个Bean属性或者一个映射条目
[] 访问一个数组或者链表的元素
+
- 减或负
*
/ or div
% or mod 取模
== or eq 测试是否相等
!= or ne 测试是否不等
< or lt 测试是否小于
> or gt 测试是否大于
<= or le 测试是否小于等于
>= or ge 测试是否大于等于
&& or and 测试逻辑与
|| or or 测试逻辑或
! or not 测试取反
empty 测试是否空值
5.6.1 EL表达式执行运算
<%@ page import="java.util.List" %>
<%@ page import="java.util.ArrayList" %>
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>


    EL表达式3


<%
    request.setAttribute("num", 13);
    Integer num = (Integer) request.getAttribute("num");
    System.out.println(num == 5);
%>

EL表达式取数据


算数运算
${requestScope.num + 10} ${requestScope.num * 10} ${requestScope.num % 5}
比较运算
${requestScope.num == 5}
${requestScope.num eq 5} equal
${requestScope.num != 5}
${requestScope.num ne 5} not equal
${requestScope.num > 5}
${requestScope.num gt 5} great than
${requestScope.num >= 5}
${requestScope.num <= 5}
${requestScope.num le 5} less than

逻辑运算
${3>2 && 4>2} ${3>2 || 1>2} ${!(num>10)}

empty运算 判断是否为空

<% String s1=""; pageContext.setAttribute("s1", s1); String s2=null; pageContext.setAttribute("s2", s2); String s3="122222"; pageContext.setAttribute("s3", s3); List list1 =new ArrayList(); pageContext.setAttribute("list1", list1); %> 可以判断空字串, ${empty(s1)}
可以判断null, ${empty(s2)}
${empty(s3)}
判断集合是否为空 ${empty(list1)}
5.6.2 empty关键字
如上代码

5.7 隐式对象

EL 表达式语言定义了11个隐式对象 ${}

隐含对象 描述
pageScope page 作用域
requestScope request 作用域
sessionScope session 作用域
applicationScope application 作用域
param Request 对象的参数,字符串
paramValues Request对象的参数,字符串集合
header HTTP 信息头,字符串
headerValues HTTP 信息头,字符串集合
initParam 上下文初始化参数
cookie Cookie值
pageContext 当前页面的pageContext
5.7.1 获得应用上下文
<%=request.getContextPath() %>
${pageContext.request.contextPath}
5.7.2 获取Cookie对象
${cookie.username}//获取名为username的cookie对象
${cookie.password}//获取名为password的cookie对象
${cookie.password.value}//获取password的cookie的value值
<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>


    Param&Cookie跳转前


<%--跳转之前到response中设置cookie--%>
<%
    Cookie cookie = new Cookie("username", "xike");
    Cookie cookie2 = new Cookie("address", "郑州");
    response.addCookie(cookie);
    response.addCookie(cookie2);
%>
<%--跳转到另一个页面后,在新页面也能获取参数cookie--%>

    
    




跳转后

<%@ page contentType="text/html;charset=UTF-8" pageEncoding="UTF-8" %>


  Param&Cookie跳转后


EL表达式获取参数的

${param.key1} ${param.key2}

获取应用的上下文 应用发布的名称

<% out.write(request.getContextPath()); %>

${pageContext.request.contextPath}

el表达式获取cookie

${cookie}
<%--cookie.cookie的名字 可以获取到这个名字的cookie对象--%>

${cookie.username}

<%--获取到cookie对象后,可以获取cookie的name/value/path/maxAge等属性 --%>

${cookie.username.name}

${cookie.username.value}


${cookie.address}

${cookie.address.name}

${cookie.address.value}

##六、JSTL标准标签库


6.1 现有问题

  • EL主要是用于作用域获取数据,虽然可以做运算判断,但是得到的都是一个结果,做展示。
  • EL不存在流程控制。比如判断。
  • EL对于集合只能做单点访问,不能实现遍历操作。比如循环。

6.2 什么是 JSTL?

  • JSTL:全称Java Server Pages Standard Tag Library

  • JSP标准标签库(JSTL)是一个JSP标签集合。

6.3 JSTL的作用

  • 可对EL获取到的数据进行逻辑操作。

  • 与EL合作完成数据的展示。

6.4 JSTL使用

  • 导入两个 jar 文件:standard.jar 和 jstl.jar 文件拷贝到 /WEB-INF/lib/
  • 在JSP页面引入标签库<% @taglib uri=“http://java.sun.com/jsp/jstl/core” prefix=“c”>

6.5 核心标签

6.5.1 条件标签if判断

语法: < /c:if>


c:if标签

正确

c:if标签

6.5.2 多条件choose判断

语法:

				结果1< /c:when> 

				结果2< /c:when> 

				结果3< /c:when> 

				结果4< /c:otherwise>

		  < /c:choose>

c:choose标签 类似switch

<% int age = 80; request.setAttribute("age", age); %> 未成年 青年 中年 老年
6.5.3 迭代foreach标签

类似于for循环

语法

var=“变量名”

items=“集合”

begin=“起始下标”

end=“结束下标”

step=“间隔长度”

varstatus=“遍历状态”>

< /c:foreach>

  

测试list集合遍历获取学生列表

学号 姓名 成绩 班级 是否是第一个 是否是最后一个 计数count 索引index
${stu.id} ${stu.name} ${stu.score} ${stu.classes} ${vs.first} ${vs.last} ${vs.count} ${vs.index}
<%
    // 模拟数据
    List emps = new ArrayList<>();
    emps.add(new Emp(1, "大壮", 15000, 18));
    emps.add(new Emp(2, "小壮", 15000, 18));
    emps.add(new Emp(3, "中洋", 16000, 18));
    emps.add(new Emp(4, "永成", 17000, 32));
    request.setAttribute("emps", emps);
%>

c:foreach循环展示员工

${e.name}- ${e.age}- ${e.salary}- ${e.id}


c:foreach循环展示员工

${e.name}- ${e.age}- ${e.salary}- ${e.id}


c:foreach循环展示员工

${e.name}- ${e.age}- ${e.salary}- ${e.id}


c:foreach循环展示员工

${e.name}- ${e.age}- ${e.salary}- ${e.id} --- ${stat.first}-${stat.last}-${stat.index}


c:foreach循环展示员工 隔行变色

${e.name}- ${e.age}- ${e.salary}- ${e.id}

${e.name}- ${e.age}- ${e.salary}- ${e.id}

6.5.4 url标签

在Cookie禁用的情况下,通过重写URL拼接JSESSIONID来传递ID值。便于下一次访问时仍可查找到上一次的Session对象。

<c:url context='${pageContext.request.contextPath}' value='/xxxController' />

//在form表单的action中嵌套动态路径
<form action="'${pageContext.request.contextPath}' value='/xxxController' />">
    
form>
  • 经验:所有涉及到页面跳转或者重定向跳转时,都应该使用URL重写。

6.6 整合

将现有的EmpProject项目进行整合,使用EL+JSTL替换脚本代码

七、MVC框架(Model-View-Controller)


7.1 MVC概念

MVC又称为编程模式,是一种软件设计思想,将数据操作、页面展示、业务逻辑分为三个层级(模块),独立完成,相互调用

  • 模型层(Model)

  • 视图(View)

  • 控制器(Controller)

7.2 MVC模式详解

MVC并不是Java独有的,现在几乎所有的B/S的架构都采用了MVC模式。

  • 视图View:视图即是用户看到并与之交互的界面,比如HTML(静态资源),JSP(动态资源)等等。
  • 控制器Controller:控制器即是控制请求的处理逻辑,对请求进行处理,负责流程跳转(转发和重定向)。
  • 模型Model:对客观世界的一种代表和模拟(业务模拟、对象模拟)。
MVC流程
jsp总结_第5张图片

7.3 优点

  • 低耦合性:模块与模块之间的关联性不强,不与某一种具体实现产生密不可分的关联性
  • 高维护性:基于低耦合性,可做到不同层级的功能模块灵活更换、插拔
  • 高重用性:相同的数据库操作,可以服务于不同的业务处理。将数据作为独立模块,提高重用性

7.4 MVC在框架中应用

MVC模式被广泛用于Java的各种框架中,比如Struts2、SpringMVC等等都用到了这种思想。

7.5 三层架构与MVC

7.5.1 三层架构

View层(表示|界面层)、Service层(业务逻辑层)、DAO层(数据访问层)

三层架构流程
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-zpoAha8K-1679828958810)(https://qfedu-1254123199.cos.ap-nanjing.myqcloud.com/img/%E4%B8%89%E5%B1%82%E6%9E%B6%E6%9E%84.png)]
7.5.2 MVC与三层架构的区别
  • MVC强调的是视图和业务代码的分离。严格的说MVC其实关注的是Web层。View就是单独的页面,如JSP、HTML等,不负责业务处理,只负责数据的展示。而数据封装到Model里,由Controller负责在V和M之间传递。MVC强调业务和视图分离。
  • 三层架构是“数据访问层”、“业务逻辑层”、“表示层”,指的是代码之间的解耦,方便维护和复用。

jsp总结_第6张图片

MVC模式

jsp总结_第7张图片

八、分页


8.1 概念

 分页是Web应用程序非常重要的一个技术。数据库中的数据可能是成千上万的,不可能把这么多的数据一次显示在浏览器上面。一般根据每行数据在页面上所占的空间设置每页显示若干行,比如一般20行是一个比较理想的显示状态。

8.2 分页实现思路

对于海量的数据查询,需要多少就取多少,显然是最佳的解决方法,假如某个表中有200万条记录,第一页取前20条,第二页取21~40条记录。

select  * from 表名 limit  0,20;//第一页
select  * from 表名 limit  20,20;//第二页
select  * from 表名 limit  40,20;//第三页

8.3 分页代码实现

步骤:

1.确定每页显示的数据数量

2.确定分页显示所需的总页数

3.编写SQL查询语句,实现数据查询

4.在JSP页面中进行分页显示设置

8.3.1 数据库准备
CREATE TABLE emp(
	id INT PRIMARY KEY AUTO_INCREMENT,
	NAME VARCHAR(20) NOT NULL,
	salary DOUBLE NOT NULL,
	age INT NOT NULL
)CHARSET=utf8;
  -- 向数据库中添加100条添加记录
8.3.2 数据库配置文件db.properties
#连接设置
driverClassName=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/emp
username=root
password=root
#
initialSize=10
#最大连接数量
maxActive=50
#
minIdle=5
#
maxWait=5000
8.3.3 PageBean类

分页数据所需要的实体类!内包含页码,页大小,总条数,总页数,起始行

package com.qf.emp.entity;

public class Page {
    private Integer pageIndex;//页码

    private Integer pageSize;//页大小  显示多少行数据

    private Integer totalCounts;//数据的总行数

    private Integer totalPages;//总页数

    private Integer startRows;//起始行

    public Page(Integer pageIndex) {
        this(pageIndex, 5);
    }

    public Page(Integer pageIndex, Integer pageSize) {
        this.pageIndex = pageIndex;
        this.pageSize = pageSize;
        this.setStartRows((pageIndex - 1) * pageSize);
    }


    public Integer getPageIndex() {
        return pageIndex;
    }

    public void setPageIndex(Integer pageIndex) {
        this.pageIndex = pageIndex;
    }

    public Integer getPageSize() {
        return pageSize;
    }

    public void setPageSize(Integer pageSize) {
        this.pageSize = pageSize;
    }

    public Integer getTotalCounts() {
        return totalCounts;
    }

    public void setTotalCounts(Integer totalCounts) {
        this.totalCounts = totalCounts;

        this.setTotalPages(totalCounts % pageSize == 0? totalCounts/pageSize:totalCounts/pageSize +1);
    }

    public Integer getTotalPages() {
        return totalPages;
    }

    public void setTotalPages(Integer totalPages) {
        this.totalPages = totalPages;
    }

    public Integer getStartRows() {
        return startRows;
    }

    public void setStartRows(Integer startRows) {
        this.startRows = startRows;
    }
}

8.3.4 创建DAO
package com.qf.emp.dao;

import com.qf.emp.entity.Emp;
import com.qf.emp.entity.Page;

import java.util.List;

public interface EmpDao {
    public List<Emp> selectAll();

    public int delete(int id);

    public int update(Emp emp);

    public Emp select(int id);
	//分页查询所有
    public List<Emp> selectAll(Page page);
	//查询数据总行数
    public long selectCount();

}

8.3.5 EmpDaoImpl实现类
package com.qf.emp.dao.impl;

import com.qf.emp.dao.EmpDao;
import com.qf.emp.entity.Emp;
import com.qf.emp.entity.Page;
import com.qf.emp.utils.DbUtils;
import org.apache.commons.dbutils.QueryRunner;
import org.apache.commons.dbutils.handlers.BeanHandler;
import org.apache.commons.dbutils.handlers.BeanListHandler;
import org.apache.commons.dbutils.handlers.ScalarHandler;

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

public class EmpDaoImpl implements EmpDao {
    private QueryRunner queryRunner = new QueryRunner();
   	//...省略其他方法
	
    @Override
    public List<Emp> selectAll(Page page) {
        try {
            List<Emp> emps = queryRunner.query(DbUtils.getConnection(),"select * from emp limit ?,?",new BeanListHandler<Emp>(Emp.class),page.getStartRows(),page.getPageSize());
            return emps;
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return null;
    }

    @Override
    public long selectCount() {
        try {
            return queryRunner.query(DbUtils.getConnection(),"select count(*) from emp;",new ScalarHandler<>());
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return 0;
    }

}

8.3.6 创建Service
package com.qf.emp.service;

import com.qf.emp.entity.Emp;
import com.qf.emp.entity.Page;

import java.util.List;

public interface EmpService {
    public List<Emp> showAllEmp();

    public int removeEmp(int id);

    public int modify(Emp emp);

    public Emp showEmp(int id);

    public List<Emp> showAllEmp(Page page);
}

8.3.7 Service实现类
package com.qf.emp.service.impl;

import com.qf.emp.dao.EmpDao;
import com.qf.emp.dao.impl.EmpDaoImpl;
import com.qf.emp.entity.Emp;
import com.qf.emp.entity.Page;
import com.qf.emp.service.EmpService;
import com.qf.emp.utils.DbUtils;

import java.util.ArrayList;
import java.util.List;

public class EmpServiceImpl implements EmpService {
    private EmpDao empDao = new EmpDaoImpl();
    //...省略其他方法

    @Override
    public List<Emp> showAllEmp(Page page) {
        List<Emp> emps = null;
        try {
            DbUtils.begin();
            //获取总行数
            long count = empDao.selectCount();
            page.setTotalCounts((int)count);
            //根据controller传递的page对象查询对应数据
            emps = empDao.selectAll(page);
            DbUtils.commit();
        } catch (Exception e) {
            DbUtils.rollback();
            e.printStackTrace();
        }
        return emps;
    }
}

8.3.8 ShowAllEmpController实现
package com.qf.emp.controller;

import com.qf.emp.entity.Emp;
import com.qf.emp.entity.Page;
import com.qf.emp.service.EmpService;
import com.qf.emp.service.impl.EmpServiceImpl;
import sun.security.util.AuthResources_it;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.List;

@WebServlet(name = "ShowAllEmpController",value = "/manager/safe/showAllEmpController")
public class ShowAllEmpController extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

        String pageIndex = request.getParameter("pageIndex");

        if(pageIndex==null){//如果是第一次访问
            pageIndex ="1";
        }

        Page page = new Page(Integer.valueOf(pageIndex));

        EmpService empService = new EmpServiceImpl();

        List<Emp> emps = empService.showAllEmp(page);

        request.setAttribute("emps",emps);

        request.setAttribute("page",page);

        request.getRequestDispatcher("/manager/safe/showAllEmp.jsp").forward(request,response);
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        doPost(request, response);
    }
}

8.3.9 showAllEmp.jsp
<%@ page import="com.qf.emp.entity.Emp" %>
<%@ page import="java.util.*" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>


    查询所有员工页面



        
编号 姓名 工资 年龄 操作
${emp.id} ${emp.name} ${emp.salary} ${emp.age} 删除 修改
首页 ">上一页 上一页 下一页 下一页 尾页
8.3.10 运行效果图
页面运行结果
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-tAk6tw1x-1679828958811)(https://qfedu-1254123199.cos.ap-nanjing.myqcloud.com/img/%E5%88%86%E9%A1%B5%E7%BB%93%E6%9E%9C%E5%9B%BE.png)]

你可能感兴趣的:(java,servlet,开发语言)