在idea中使用sprint boot创建jsp工程
jsp技术简介
JSP(全称JavaServer Pages)是由Sun Microsystems公司主导创建的一种动态网页技术标准。JSP部署于网络服务器上,可以响应客户端发送的请求,并根据请求内容动态地生成HTML、XML或其他格式文档的Web网页,然后返回给请求者。JSP技术以Java语言作为脚本语言,为用户的HTTP请求提供服务,并能与服务器上的其它Java程序共同处理复杂的业务需求。
jsp技术实现思路
JSP将Java代码和特定变动内容嵌入到静态的页面中,实现以静态页面为模板,动态生成其中的部分内容。JSP引入了被称为“JSP动作”的XML标签,用来调用内建功能。另外,可以创建JSP标签库,然后像使用标准HTML或XML标签一样使用它们。标签库能增强功能和服务器性能,而且不受跨平台问题的限制。JSP文件在运行时会被其编译器转换成更原始的Servlet代码。JSP编译器可以把JSP文件编译成用Java代码写的Servlet,然后再由Java编译器来编译成能快速执行的二进制机器码,也可以直接编译成二进制码。
在idea中使用spring boot搭建jsp开发环境
spring boot已经成为时下最流行的java开发框架,为了让同学们能够在最新java开发技术基础上使用jsp开发技术,本次课程将直接在spring boot的基础上搭建jsp的开发环境。
1、spring boot简介
Spring boot是Spring家族中的一个全新的框架,它用来简化Spring应用程序的创建和开发过程,简化了软件开发环境和java 库的配置过程,提高了软件开发效率。
2.在idea中使用Spring Initializr创建并测试spring boot程序
1、file——new——project(或者mudole)。选中spring initializr。我们选择默认的初始化下载jar的网址即可。点击next
如下图,配置即可。
点击下一步,界面如下图,该界面罗列和很多常用的spring boot常用的插件,通过选择这些插件,idea工具会自动帮我们把插件加入到工程中。我们本次创建的是一个web项目,所以选中如图中的按钮。
点击下一步,设置项目名字和存储路径,然后点击finish,到此项目创建成功。
创建好以后,文件的列表如下图所示:
各个目录作用解释如下:
1.(.mvn)目录,项目自动创建的maven相关插件目录。
2.(src)开发项目的所有代码写在这个文件夹中。
3.(resources)目录是项目的静态资源文件,所有不被编译的文件都可以放入这个目录当中,如项目的配置文件application.properties或者项目中使用到的图片文件等。
4.test目录是测试文件,所有的单元测试代码都写在这个文件当中
5.mvmw maven脚本文件,用于在linux文件系统中打包使用。
6、mvmw.cmd maven脚本文件,用于在windows系统中打包项目使用
7、pom.xml 中包括了项目所使用的依赖配置和插件。
3.pom文件解释
4.0.0
org.springframework.boot
spring-boot-starter-parent
2.1.3.RELEASE
com.example.demo
01-springboot-web
0.0.1-SNAPSHOT
01-springboot-web
Demo project for Spring Boot
1.8
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-maven-plugin
4.springboot的入口main方法
spring boot不同于传统的spring mvc项目。路径为: com.example.demo.DemoApplication.java
package com.example.demo;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
//@SpringBootApplication注解,表示这是springboot程序
@SpringBootApplication
public class Application {
public static void main(String[] args) {
// 这个方法是启动自己application.class 这个类,这样他就能启动springboot程序,然后启动spring容器,然后启动内嵌的Tomcat
SpringApplication.run(Application.class, args);
}
}
5.创建一个controller类
创建controller类后,目录结构如下图所示
HelloController.java文件的代码如下图所示:
package com.cjp.springboot.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class HelloController {
@RequestMapping("/boot/hello") //请求路径
public @ResponseBody String hello(){
return "hello the world!";
}
}
6.测试springboot程序
创建程序到此已经结束了。下面我们启动一下: 在目录中选中application——右击——“run application”。等待编译完成。编译完成后,显示端口为8080
到此,springboot程序启动成功了,然后在浏览器中输入测试地址,查看结果
7.发布springboot程序
项目项目已经完成了,如果需要发布也非常的简单。因为我们已经在pom 文件中引入了打包依赖 ,借助这个工具可以很方便的发布springboot程序
org.springframework.boot
spring-boot-maven-plugin
我们只需要点击idea中的maven——lifecycle——package。
找到jar后,我们可以在命令行窗口执行java -jar spring-boot-01-helloworld-1.0-SNAPSHOT.jar 即可。 启动后,我们可以在浏览器中直接访问localhost:8080/boot/hello,可以查看执行结果。。
8.spring boot总结
在这个程序,我们使用到了spring mvc,但是我们并没有注入spring mvc 的配置文件,也不需要在Tomcat中部署,同样不需要引入很多的jar包。这是因为我们在前面的springboot开发web项目的起步依赖中已经自动引入了需要依赖的jar
spring boot 的父级依赖spring-boot-starter-parent配置之后,当前项目变成了spring boot 项目
spring -boot-starter-parent 是一个特殊的starter依赖,它用来提供相关的maven默认依赖,使用它之后,常用的jar包依赖可以省去version 配置。我们在查看pom.xml 文件发现我们的相关依赖项都是没有填写版本号的。这是因为 springboot的父级依赖是Spring Boot的版本仲裁中心,以后我们导入依赖默认是不需要写版本;(没有在dependencies里面管理的依赖自然需要声明版本号)
spring boot 提供了很多的默认的jar 依赖,可以通过查看spring boot 的父级依赖。
如果不想使用某个默认的依赖版本,可以通过修改pom .xml 文件属性配置,从而覆盖各个依赖项。比如覆盖spirng 版本。
@springbootapplication 注解是springboot项目的核心注解,主要作用的开启springboot的自动配置。
main 方法是一个标准的java程序的main 方式,主要作用是作为项目的启动入口
@controller和@responseBody 依然是spring mvc的内容,因为spring boot 的里面最常用的是spring mvc + spring + mybatis 框架
添加jsp支持
springboot并没有默认支持jsp,要想让springboot支持jsp,需要添加jstl标签库并给tomcat添加jsp编译支持。
1、在pom文件中添加jsp支持
javax.servlet
jstl
org.apache.tomcat.embed
tomcat-embed-jasper
2.配置jsp模板路径
在resources/application.properties文件中添加jsp模板文件的配置路径
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
prefix 用于指定jsp文件的路径,suffix用于指定jsp文件的后缀名
3、添加controller
通过返回ModelAndView和String两种方式使用jsp
@Controller
public class HelloController {
@ResponseBody
@RequestMapping("/hi")
public String hi(){
return "h1";
}
//通过返回ModelAndView方式实现
@RequestMapping("/hello")
public ModelAndView hello(HttpServletResponse response)throws IOException {
ModelAndView modelAndView = new ModelAndView();
modelAndView.setViewName("hello");
modelAndView.addObject("username","李白");
return modelAndView;
}
//通过返回String实现
@RequestMapping("/abc")
public String abc(){
return "hello";
}
}
4.建立jsp页面
根据resources/application.properties
配置文件的描述,controller中abc路径返回的hello页面的完整路径应该是webapp/WEB-INF/jsp/hello.jsp。其路径结构如图所示
然后在jsp页面中添加代码如下
<%@page contentType="text/html; charset=UTF-8" language="java" %>
jsp页面
至此完成第一个jsp页面的建立,其测试过程同前面springboot测试过程,这里不再赘述。
5.添加jsp支持总结
springboot已经不再讲自己定义为单一的web开发框架,而是将所有java开发模式都纳入到框架中来,所以不再默认支持jsp,若需要使用jsp。则需要手动添加jsp支持。
添加jsp支持需要在pom中添加两个库文件jstl标签库和内置tomcat编译jsp的支持库
需要配置jsp的文件路径和后缀名
在controller中使用jsp编程有两种方式:返回ModelAndView和String两种方式
编程体验优化
在前面的编程练习过程当中,我们发现有两个地方比较麻烦,一是在首次加载pom中的库的时候比较耗时,二是每次修改代码后都需要重启服务器才能生效。下面讲解解决这两个问题的方法。
1、解决pom中库下载慢的问题
出现这种问题的原因在于pom中所有的库都是默认从核心仓库中下载的,而核心仓库在国外,因此导致下载速度慢。好在阿里巴巴做了pom库的镜像,通过将maven的下载镜像配置到阿里巴巴的镜像源,可以加快pom库的下载速度。具体操作不走如下:
在idea中点击file->settings 打开如下窗口,然后在左上角搜索maven,将右下角的User setting file的Override复选框选中,这一步可以容许我修改settings.xml文件来配置maven的默认操作
按照上述目录打开maven的settings文件,若没有setting文件可手动创建一个settings.xml文件。将里面内容填写如下:
aliyun-public
*
aliyun public
https://maven.aliyun.com/repository/public
aliyun-central
*
aliyun central
https://maven.aliyun.com/repository/central
aliyun-spring
*
aliyun spring
https://maven.aliyun.com/repository/spring
aliyun-spring-plugin
*
aliyun spring-plugin
https://maven.aliyun.com/repository/spring-plugin
aliyun-apache-snapshots
*
aliyun apache-snapshots
https://maven.aliyun.com/repository/apache-snapshots
aliyun-google
*
aliyun google
https://maven.aliyun.com/repository/google
aliyun-gradle-plugin
*
aliyun gradle-plugin
https://maven.aliyun.com/repository/gradle-plugin
aliyun-jcenter
*
aliyun jcenter
https://maven.aliyun.com/repository/jcenter
aliyun-releases
*
aliyun releases
https://maven.aliyun.com/repository/releases
aliyun-snapshots
*
aliyun snapshots
https://maven.aliyun.com/repository/snapshots
aliyun-grails-core
*
aliyun grails-core
https://maven.aliyun.com/repository/grails-core
aliyun-mapr-public
*
aliyun mapr-public
https://maven.aliyun.com/repository/mapr-public
repo1
central
Human Readable Name for this Mirror.
http://repo1.maven.org/maven2/
repo2
central
Human Readable Name for this Mirror.
http://repo2.maven.org/maven2/
文件中13个mirror标签,每个mirror标签代表一个镜像源。最后两个是默认的中央仓库,速度一般比较慢,前面11个都是阿里云的源。当maven下载库的时候就会从上往下依次测试每个源是否可以下载当前库,若能下载则采用当前源,若不能下载则测试下一个源。因此,阿里云的源必须配置在中央仓库的前面才能生效。
2、springboot 热部署
springboot热部署的实现思路是使用spring-boot-devtools监听classpath下的文件变动并立即重启应用。通过配置springboot热部署,可以使代码保存后立马生效,配置步骤如下:
在pom文件中添加spring-tool-devtools依赖
org.springframework.boot
spring-boot-devtools
true
org.springframework.boot
spring-boot-maven-plugin
true
optional标签中的 true
表示依赖不会传递。 若要额外监听其他路径下的文件可通过在src/main/resources/application.properties
中添加配置实现。如通过如下配置让deltool监听application.properties文件的变化
#热部署生效
spring.devtools.restart.enabled=true
#设置重启的目录,检索目录(resources/static、resources/templates)
spring.devtools.restart.additional-paths= src/main/java
#classpath目录下的WEB-INF文件夹内容修改不重启
#spring.devtools.restart.exclude= WEB-INF/**
在idea中修改配置,勾选Build project automatically
按 ctrl+shift+alt+/,选择Registry,勾选图示选项。
做完以上步骤后就可以实现热加载了。但通过测试后发现热加载的反应有点慢,需在使用过程中特别关注控制台信息。