1 第2-2课:Spring Boot 项目中使用JSP
JSP(Java Server Pages,Java 服务器页面)是一个简化的 Servlet 设计,它是由 Sun Microsystems 公司倡导、许多公司参与一起建立的一种动态网页技术标准。JSP 技术类似 ASP 技术,它是在传统的网页 HTML(标准通用标记语言的子集)文件(.html)中插入 Java 程序段(Scriptlet)和 JSP 标记(tag),从而形成 JSP 文件,后缀名为(*.jsp)。用 JSP 开发的 Web 应用是跨平台的,既能在 Linux 下运行,也能在其他操作系统上运行。
JSP 其实就是 Java 为了支持 Web 开发而推出的类前端 Servlet,可以在 JSP 中写 Java 或者 Html 语法等,后端根据 JSP 语法渲染后返回到前端显示,在没有模板引擎之前 JSP 是 Java 程序员开发人员的首选,到现在仍然有很多公司使用 JSP 开发后台管理系统。本课内容将介绍如何在 Spring Boot 项目中使用 JSP。
1.1 快速上手
1.1.1 项目结构
首先看一下添加 JSP 支持后的项目结构:
+
+
+
+
+
+
+
+
+
+
对比以前的项目结构 main 目录下多了 webapp 目录,用来存放目录 jsp 文件。
1.1.2 配置文件
需要在配置文件中指定 jsp 的位置和后缀。
: /WEB-INF/jsp/
: .jsp
- spring.mvc.view.prefix 指明 jsp 文件在 webapp 下的哪个目录
- spring.mvc.view.suffix 指明 jsp 以什么样的后缀结尾
1.1.3 引入依赖包
org.springframework.boot
spring-boot-starter-web
javax.servlet
jstl
org.apache.tomcat.embed
tomcat-embed-jasper
spring-boot-starter-web 包依赖了 spring-boot-starter-tomcat 不需要再单独配置。引入 jstl 和内嵌的 tomcat,jstl 是一个 JSP 标签集合,它封装了 JSP 应用的通用核心功能。tomcat-embed-jasper 主要用来支持 JSP 的解析和运行。
1.1.4 编写页面
简单写一个页面:
Time: ${time}
Message: ${message}
很简单的一个页面,展示后端传到页面的时间和消息。
1.1.5 后端程序
{
(
)
{
model.put(
,
Date());
model.put(
,
);
;
}
}
time 获取当前时间,message 赋值为 hello world。
1.1.6 测试
cmd 进入项目跟路径下:
...\spring-boot-jsp
执行以下命令启动:
启动完成后,在浏览器中访问地址:http://localhost:8080/,返回信息如下:
:
11 13
2018
:
说明项目运行成功。
1.2 常用示例
页面中常用的展示后端传值、if 判断、循环等功能,可以使用 jstl 语法处理,也可以直接写 Java 代码来实现这些逻辑,在 jsp 页面中这两种方式都支持。但不建议在 jsp 页面中编写大量的 Java 代码,从而导致前端业务复杂,可读性差等问题。下面通过一些小的示例来学习。
在 WelcomeController 类中定义一个 user() 的方法,设置一些值从后端传递到前端:
@GetMapping(
)
public
user(
<
,
> model, HttpServletRequest request) {
model.put(
,
);
model.put(
,
);
request.getSession().setAttribute(
,
);
;
}
将参数和值以键值对的方式存储在 Map 中,jsp 页面可以直接根据属性名来获取值,也可以通过 request 来传递后端属性和值,返回值会以键值对的方式传递到 user.jsp 页面。
在 user.jsp 文件头部添加两个标签:
引入第一个标签是为了让页面支持中文展示,第二个标签引入表示页面使用 jstl 语法来处理页面逻辑。
1.2.1 Java 代码
可以直接在 jsp 页面中使用 Java 代码,如果是一行 Java 代码使用<%= %>
的语法,如果是多行 Java 代码则使用<% %>
的语法,示例如下:
<h3>
一行
Java
代码
</h3>
<p>
今天的日期是
: <%=(
java.util.Date())%>
</p>
<h3>
多行
Java
代码
</h3>
<p>
你的
IP
地址是:
<%
.println(
+ request.getRemoteAddr()+
);
.println(
);
%>
</p>
For 循环是页面最常用的功能之一,一般用在循环展示表格、列表等。
<h3>For
循环实例
</h3>
<%
count = (
)session.getAttribute(
);
(
fontSize =
; fontSize <=count; fontSize++){
%>
纯洁的微笑
<br />
<%}%>
根据后端传递的 count 值来选择前端页面循环次数。
1.2.2 jstl 语法
页面常常会使用一些逻辑判断,使用 jstl 语法很容易实现这些功能。
标签
c:if
用户名为:
username
使用 jstl 标签的<c:if>
来判断传递过来的 username 是否为空,如果不为空将 username 展示到页面。当有多条件判断时可以使用 <c:choose>
更方便。
标签
c:choose
太惨了。
不错的薪水,还能生活。
什么都没有。
上述代码根据 salary 值的大小来输出不同的内容。
jstl 语法可以支持常见的功能,这里只是列举最常用的两个作为示例。
1.2.3 页面布局
一般网站的每个页面都拥有相同的页眉和页脚,这两部分内容一般很少发生变动,这部分内容特别适合将它提取出来,让每个页面来重复利用。
JSP 可以通过 include 指令来实现此效果,include 指令用于在编译阶段包括一个文件,这个指令告诉容器在编译阶段,把其他外部文件的内容合并到当前 JSP 文件中,可在 JSP 页面的任何位置使用 include 指令进行编码。
include 有两种用法:<%@ include file="relative url"%>
和<jsp:include page="relative url" flush=”true”/>
。前者是在翻译阶段执行,后者是在请求处理阶段执行;前者叫作静态包含,后者叫作动态包含,会在执行时检查包含内容变化。两者使用语法没有太大区别,下面举一个简单示例。
新建一个 footer.jsp 内容如下:
我是页尾
在 user.jsp 页面中引入 footer.jsp:
布局
这样在访问 user.jsp 时,会将 footer.jsp 内容展示到 user.jsp 页面引入的位置。
上述代码都完成后,整体看一下页面的效果,启动项目在浏览器中输入网址:http://localhost:8080/user,页面展示效果如下:
1.3 调试和部署
1.3.1 在 IDEA 中运行
如果像其他项目一样,直接在 IDEA 中通过 main 方法来启动项目,在访问测试的时候会出现 404 not found。
这是因为 Spring Boot JSP 项目需要额外进行一个设置:选择 Edit Configurations 选项,打开 Run/Debug Configurations:
设置 Working directory 的路径为项目根路径:
然后重启项目就可以正常的访问到页面内了。
1.3.2 在单独的 Tomcat 中运行
(1)在 pom.xml 里设置打包格式为 war。
war
(2)排除内嵌的 Tomcat 依赖
打包时排除掉内嵌的 Tomcat 依赖,避免 jar 包冲突。
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-tomcat
(3)Servlet 的支持
Spring Boot 项目必须实现 SpringBootServletInitializer 接口的 configure() 方法才能让外部容器运行 Spring Boot 项目,启动类同目录下创建 ServletInitializer 类:
{
{
application.sources(JspApplication.class);
}
}
(4)打包发布,在项目根目录执行 maven 命令:
mvn clean
(5)将 war 包发布到 Tomcat 即可。
1.4 总结
通过本课的学习我们掌握了如何在 Spring Boot 项目中集成 JSP,Spring Boot 支持使用内嵌的 Tomcat 来运行 JSP,也支持将项目打包成 War 包部署到独立的 Tomcat 中。实际项目中推荐使用单独的 Tomcat 来部署使用 JSP 的项目,内嵌的 Tomcat 还不是很稳定,偶尔会出现访问迟缓的现象。