引入依赖

<!--WEB支持--><dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId></dependency><!--jsp页面利用jstl标签--><dependency> <groupId>javax.servlet</groupId> <artifactId>jstl</artifactId></dependency><!--用于编译jsp--><dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> <scope>provided</scope></dependency>

利用内嵌的tomcat容器来运行的话只要这3个就好了。
这里先容下maven中scope依赖范围的观点,由于后续涉及到这个会有问题。

依赖范围便是用来掌握依赖和三种classpath(编译classpath,测试classpath、运行classpath)的关系,Maven有如下几种依赖范围:

服务器maven预编译jspSpring Boot干货系列开辟Web运用之JSP篇圣诞节快活 Node.js

compile:编译依赖范围。
如果没有指定,就会默认利用该依赖范围。
利用此依赖范围的Maven依赖,对付编译、测试、运行三种classpath都有效。
范例的例子是spring-code,在编译、测试和运行的时候都须要利用该依赖。
test: 测试依赖范围。
利用次依赖范围的Maven依赖,只对付测试classpath有效,在编译主代码或者运行项目的利用时将无法利用此依赖。
范例的例子是Jnuit,它只有在编译测试代码及运行测试的时候才须要。
provided:已供应依赖范围。
利用此依赖范围的Maven依赖,对付编译和测试classpath有效,但在运行时候无效。
范例的例子是servlet-api,编译和测试项目的时候须要该依赖,但在运行项目的时候,由于容器以及供应,就不须要Maven重复地引入一遍。

application.properties配置

要支持jsp,须要在application.properties中配置返回文件的路径以及类型

spring.mvc.view.prefix: /WEB-INF/jsp/spring.mvc.view.suffix: .jsp

这里指定了返回文件类型为jsp,路径是在/WEB-INF/jsp/下面。

掌握类

上面步骤有了,这里就开始写掌握类,直接上大略的代码,跟正常的springMVC没啥差异:

@Controller@RequestMapping(\"大众/learn\"大众)public class LearnResourceController { @RequestMapping(\"大众\"大众) public ModelAndView index(){ List<LearnResouce> learnList =new ArrayList<LearnResouce>(); LearnResouce bean =new LearnResouce(\公众官方参考文档\公众,\公众Spring Boot Reference Guide\公众,\"大众http://docs.spring.io/spring-boot/docs/1.5.1.RELEASE/reference/htmlsingle/#getting-started-first-application\"大众); learnList.add(bean); bean =new LearnResouce(\公众官方SpriongBoot例子\"大众,\"大众官方SpriongBoot例子\公众,\"大众https://github.com/spring-projects/spring-boot/tree/master/spring-boot-samples\"大众); learnList.add(bean); bean =new LearnResouce(\公众龙国学院\"大众,\公众Spring Boot 教程系列学习\公众,\"大众http://www.roncoo.com/article/detail/125488\公众); learnList.add(bean); bean =new LearnResouce(\公众嘟嘟MD独立博客\"大众,\"大众Spring Boot干货系列 \"大众,\"大众http://tengj.top/\"大众); learnList.add(bean); bean =new LearnResouce(\"大众后端编程嘟\"大众,\"大众Spring Boot教程和视频 \公众,\公众http://www.toutiao.com/m1559096720023553/\"大众); learnList.add(bean); bean =new LearnResouce(\"大众程序猿DD\"大众,\公众Spring Boot系列\"大众,\公众http://www.roncoo.com/article/detail/125488\"大众); learnList.add(bean); bean =new LearnResouce(\"大众纯洁的微笑\公众,\"大众Sping Boot系列文章\"大众,\"大众http://www.ityouknow.com/spring-boot\"大众); learnList.add(bean); bean =new LearnResouce(\公众CSDN——小当博客专栏\"大众,\"大众Sping Boot学习\"大众,\"大众http://blog.csdn.net/column/details/spring-boot.html\"大众); learnList.add(bean); bean =new LearnResouce(\"大众梁桂钊的博客\"大众,\"大众Spring Boot 揭秘与实战\"大众,\"大众http://blog.csdn.net/column/details/spring-boot.html\公众); learnList.add(bean); bean =new LearnResouce(\"大众林祥纤博客系列\"大众,\"大众从零开始学Spring Boot \"大众,\公众http://412887952-qq-com.iteye.com/category/356333\公众); learnList.add(bean); ModelAndView modelAndView = new ModelAndView(\公众/index\"大众); modelAndView.addObject(\"大众learnList\"大众, learnList); return modelAndView; }}

jsp页面编写

<body style=\"大众background-image: none;\公众><div class=\"大众body_wrap\"大众> <div class=\公众container\公众> <div class=\公众alert alert-success text-center\"大众 role=\"大众alert\公众>Sptring Boot学习资源大奉送,爱我就关注嘟嘟"大众号:嘟爷java超神学堂</div> <table class=\公众table table-striped table-bordered\公众> <tr> <td>作者</td> <td>教程名称</td> <td>地址</td> </tr> <c:forEach var=\"大众learn\"大众 items=\"大众${learnList}\"大众> <tr class=\"大众text-info\"大众> <td th:text=\"大众${learn.author}\公众>嘟嘟MD</td> <td th:text=\公众${learn.title}\公众>SPringBoot干货系列</td> <td><a href=\公众#\"大众 th:href=\"大众${learn.url}\"大众 class=\公众btn btn-search btn-green\公众 target=\"大众_blank\公众><span>点我</span></a> </td> </tr> </c:forEach> </table> </div></div></body>

启动类

启动类不变还是最大略的

@SpringBootApplicationpublic class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); }}

内嵌Tomcat容器运行项目

基本配置好了就可以启动项目,通过http://localhost:8080/learn 访问,我利用的SpringBoot是1.5.2版本,jdk1.8,以前先容过,运行项目有三种办法,这里我都做过了一次测试,创造在maven中jasper依赖有加provided和注释掉该依赖范围运行的效果不大一样,详细比拟如下:

有添加provided的情形:

右键运行启动类,访问页面报404缺点利用spring-boot:run运行正常打包成jar,通过 java -jar demo-0.0.1-SNAPSHOT.jar 运行报错打包成war,通过 java -jar demo-0.0.1-SNAPSHOT.war 运行正常

把provided 注释掉的情形

右键运行启动类,访问页面正常spring-boot:run运行 访问页面正常打包成jar,通过 java -jar demo-0.0.1-SNAPSHOT.jar 运行报错打包成war,通过 java -jar demo-0.0.1-SNAPSHOT.war 运行正常

我测试了好几次都是这样,便是有加provided的时候,右键运行启动类访问页面的时候,提示404缺点。

其他3种情形都一样, jar运行也报404,spring-boot:run以及war运行都可以。

为什么jar包运行弗成呢,我们打开打包的jar和war分别看看差异,如下2图所示:

从上面可以看出来,jar包运行的时候会404缺点,由于默认jsp不会被拷贝进来,而war包里面有包含了jsp,以是没问题。

内嵌Tomcat属性配置

关于Tomcat的偶有属性都在org.springframework.boot.autoconfigure.web.ServerProperties配置类中做了定义,我们只需在application.properties配置属性做配置即可。
通用的Servlet容器配置都已”server”旁边前缀,而Tomcat特有配置都以”server.tomcat”作为前缀。
下面举一些常用的例子。

配置Servlet容器:

#配置程序端口,默认为8080server.port= 8080#用户绘画session过期韶光,以秒为单位server.session.timeout=# 配置默认访问路径,默认为/server.context-path=

配置Tomcat:

# 配置Tomcat编码,默认为UTF-8server.tomcat.uri-encoding=UTF-8# 配置最大线程数server.tomcat.max-threads=1000

更为详细的Servlet容器配置以及Tomcat配置,可以前往博主之前文章查看:Spring Boot干货系列:常用属性汇总

外部的Tomcat做事器支配war包

Spring Boot项目须要支配在外部容器中的时候,Spring Boot导出的war包如果直接在Tomcat的支配会报错,不信你可以试试看。

须要做到下面两点修正才可以:

继续SpringBootServletInitializer外部容器支配的话,就不能依赖于Application的main函数了,而是要以类似于web.xml文件配置的办法来启动Spring运用高下文,此时我们须要在启动类中继续SpringBootServletInitializer并实现configure方法:

public class Application extends SpringBootServletInitializer { @Override protected SpringApplicationBuilder configure(SpringApplicationBuilder application) { return application.sources(Application.class); }}

这个类的浸染与在web.xml中配置卖力初始化Spring运用高下文的监听器浸染类似,只不过在这里不须要编写额外的XML文件了。

pom.xml修正tomcat干系的配置如果要将终极的打包形式改为war的话,还须要对pom.xml文件进行修正,由于spring-boot-starter-web中包含内嵌的tomcat容器,以是直接支配在外部容器会冲突报错。
这里有两种方法可以办理,如下方法一:

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <exclusions> <exclusion> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </exclusion> </exclusions></dependency>

在这里须要移除对嵌入式Tomcat的依赖,这样打出的war包中,在lib目录下才不会包含Tomcat干系的jar包,否则将会涌现启动缺点。

还有一个很关键的关键点,便是tomcat-embed-jasper中scope必须是provided。

<dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> <scope>provided</scope></dependency>

由于SpringBootServletInitializer须要依赖 javax.servlet,而tomcat-embed-jasper下面的tomcat-embed-core中就有这个javax.servlet,如果没用provided,终极打好的war里面会有servlet-api这个jar,这样就会跟tomcat本身的冲突了。
这个关键点同样适应于下面说的第二种方法。

方法二:

直接添加如下配置即可:

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> <scope>provided</scope></dependency>

provided的浸染上面已经先容的很透彻了,这里就不啰嗦了,这种办法的好处是,打包的war包同时适宜java -jar命令启动以及支配到外部容器中。

如果你不喜好默认的打包名称,你可以通过节点里添加内容。

<build> <finalName>springBootJsp</finalName></bulid>

末了启动tomcat输入http://localhost:8080/springBootJsp/learn 查看效果,还是美美哒

关于利用jar支配

上面已经测试过了,正常情形下包含jsp的页面是无法用jar的运行的,由于jsp默认是在webapp目录下,可是打包成jar是没有webapp这个目录构造的。

虽然网上有先容说通过pom.xml配置,把WEB-INF目录复制到META-INF/resources下面。
但是博主试了一整天还是访问不了,末了放弃了。
各位如何有兴趣可以连续考试测验,毕竟war也可以通过java -jar命令来启动的不是么。

总结

我相信全网都找不到一篇有我这篇这么详细的先容Spring Boot利用jsp的文章。
有很多人问我,为什么我的很多文章这么大略易懂,我每次都是哭着回答他们四个字:主题阅读,天知道我参考了多少篇网上的文章,外加多少本相关书本中关于这个章节的内容,反复比拟提炼,末了才产出对应的博文。
说真的,我很倾慕你们在这个信息爆炸的时期,刚好看到一篇自己要学习的技能的好文章,少走多少弯路。

写在末了:

码字不易看到末了了,那就点个关注呗,只收藏不点关注的都是在耍泼皮!

关注并私信我“架构”,免费送一套Java架构资料,先到先得!