欢迎关注我们的专栏 学透 Spring Boot
- 一、创建一个简单Web应用
本篇文章,我们将会比较
Spring
框架和Spring Boot
的区别。
什么是 Spring?
也许你在项目中已经可以很熟练的使用 Spring 了,但是当被问到这个问题时,会不会犹豫一下,停下来思索一番。
简单来说,Spring 框架为开发 Java 应用程序提供了全面的基础设施支持。
Spring 框架提供了很多有用的特性,比如IOC 和 AOP,还有很多开箱即用的模块,用一张图可以很直观的体现这一点:
有了这些模块,可以大大加快我们开发一个应用的速度。
就拿数据持久化举例,我们的应用需要从数据库中读取数据时,如果不用Spring JDBC(也不用持久化框架,比如Hibernate或MyBatis)时,我们直接操作JDBC。
在使用 JDBC 时,我们需要手动创建数据库连接、执行查询语句、处理结果集等。
下次如果要存取另一张表的数据,我们还需要把这些事再做一遍,代码冗余而且大同小异,结果集处理枯燥更容易出错。
public class StudentDAO {private Connection connection;// Constructorpublic StudentDAO() {try {connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/mydatabase", "username", "password");} catch (SQLException e) {e.printStackTrace();}}public void getStudents() {String sql = "SELECT * FROM students";try {PreparedStatement statement = connection.prepareStatement(sql);ResultSet resultSet = statement.executeQuery();while (resultSet.next()) {int id = resultSet.getInt("id");String name = resultSet.getString("name");int age = resultSet.getInt("age");System.out.println("ID: " + id + ", Name: " + name + ", Age: " + age);}} catch (SQLException e) {e.printStackTrace();}}
}
但是如果我们使用 Spring JDBC,我们的代码将会变得非常的简洁:
public class StudentDAO {private JdbcTemplate jdbcTemplate;public StudentDAO(DataSource dataSource) {this.jdbcTemplate = new JdbcTemplate(dataSource);}public List<Student> getStudents() {String sql = "SELECT * FROM students";RowMapper<Student> rowMapper = (resultSet, rowNum) -> {Student student = new Student();student.setId(resultSet.getInt("id"));student.setName(resultSet.getString("name"));student.setAge(resultSet.getInt("age"));return student;};return jdbcTemplate.query(sql, rowMapper);}
}
当然使用Hibernate 和 MyBatis也一样非常的简洁,这说明了使用框架带来的好处!
打个比喻,使用框架前相当于是骑自行车,很多步骤都要我们手动完成,但是有了框架,就相当于开上了汽车,我们只需要在乎最核心的几个环节就可以了,其它都交给框架处理。
什么是 Spring Boot
可以说 Spring Boot 是 Spring 框架的扩展。它去除了开发 Spring 应用所需的样板配置。
简单点说,Spring Boot 是基于 Spring 框架的,它的作用是极大的简化了 Spring 项目的开发。
Spring Boot 给我们提供了很多:
- 提供了很多
starter
依赖,引入一些模块变得非常简洁 - 内嵌服务器(如Tomcat等)的方式,让应用部署变得非常简单
- 开箱即用的功能,比如性能监控、健康检查等
- 自动配置
- ……
Maven 依赖对比
介绍完 Spring 和 Spring Boot,我们再具体比较它们在多个方面的差异。
首先要比较的是 Maven 依赖的不同,这也是我们开发项目尤其是项目前期时最重要的工作。
用 Spring 创建一个 Web 应用时,我们至少需要引入下面几个依赖:
<dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.3.5</version>
</dependency>
<dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.3.5</version>
</dependency>
当然,因为Maven的依赖传递,实际被动引入的远不止这两个包
如果我们使用 Spring Boot,将会变得更简洁:
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId><version>3.2.4</version>
</dependency>
甚至版本都不用声明,默认会和 parent 依赖的版本一致。
在 IDEA 中打开 Maven 视图,我们可以在依赖中清晰得看到依赖传递的关系,starter-web
除了引入 spring-web
和 spring-webmvc
外,还引入了另外两个starter starter-json
和 starter-tomcat
,而这两个starter 又引入了其它的依赖:
所以,可以看到通过这些 starter
, Spring Boot 可以一次性引入一组依赖。Spring Boot 将我们经常配合使用的一组依赖进行打包,并提供一个依赖项描述文件,让我们可以轻松快速的集成这个模块。
starter不仅省去了我们要一个个配置依赖到手软的痛苦,还避免了各种依赖间版本冲突或者不兼容的麻烦。
Spring Boot 的 starter 更深入的研究我们将在后面的章节专门介绍。
Spring Boot 为 Spring 模块提供了一系列的 starter 依赖:
- spring-boot-starter-data-jpa
- spring-boot-starter-security
- spring-boot-starter-test
- spring-boot-starter-web
- spring-boot-starter-thymeleaf
- ……
还有很多很多,完整的列表查看这里:Spring Boot Starter 列表
MVC 配置对比
作为一个 Web 项目,我们这里用整合 JSP 来对比 Spring 和 Spring Boot。
使用 Spring MVC 时,我们通常第一件要做的事就是在 web.xml
配置 Servlet和映射:
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><context-param><param-name>contextConfigLocation</param-name><param-value>com.baeldung</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value></param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern></servlet-mapping>
</web-app>
然后,我们还要在配置类中启用MVC,使用注解@EnableWebMvc
。还需要定义一个视图解析器,这样可以解析视图并返回给控制器。
@EnableWebMvc
@Configuration
public class ClientWebConfig implements WebMvcConfigurer { @Beanpublic ViewResolver viewResolver() {InternalResourceViewResolver bean= new InternalResourceViewResolver();bean.setViewClass(JstlView.class);bean.setPrefix("/WEB-INF/view/");bean.setSuffix(".jsp");return bean;}
}
最后,我们才开始编写 Controller。可以看到,上面的配置非常的乏味,而且绝大部分使用 Spring MVC 的项目,配置基本都大同小异,这就是所谓的模版配置
。
但是如果我们使用的是 Spring Boot,你只需要在 application.properties
中添加两行配置即可:
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
恭喜你,你的 Spring MVC 已经配置好了。
所有的 Spring 配置 都会被 Spring Boot 自动完成,也就是传说中的自动配置
。
自动配置是Spring Boot 提供的一个非常强大的特性,这里再挖个坑,后面的章节会深入研究。
应用启动
我们需要把 Spring 开发的 Web 项目运行起来,还需要很多工作:
- 在 web.xml 中配置
ContextLoaderListener
和DispatcherServlet
- 把我们的 Web 应用导出war包
- 部署和配置 Tomcat 服务器
- 把 war 包部署到Tomcat指定路径,然后启动 Tomcat
但是如果你使用的是 Spring Boot,那么你只需要做一点点工作:
- 通过mvn把应用打包成 jar 包:
mvn package
- 通过 java 命令启动 jar 包:
java -jar skyboot.jar
这样你的 Web 应用就启动了,完全不用任何的配置!是不是非常的简便!
再挖一个坑,后面的章节会深入学习 “内嵌 Tomcat”的原理。
总结
通过上面的 依赖配置
、MVC 配置
、应用启动
几个角度,对比了分别使用 Spring 和 Spring Boot 的难以程度,结果不言而喻。其实 Spring Boot 比我们本文演示的还要强大的多,这在我们后面的文章会一一介绍。
试想想,如果我们要使用 Spring 开发很多个微服务,是件多么棘手的事,就算不从零开始配置,复制粘贴改一改也是很大的工作量,而且极容易出错。
但是如果使用 Spring Boot,开发一个应用变得手拿把攥。
这就是 Spring Boot 的意义,让 Spring 应用的开发和部署变得非常简便。