Spring 和 SpringBoot 最核心的 3 大區(qū)別,詳解!
掃描二維碼
隨時隨地手機看文章
作者:樂傻驢 uee.me/cNDC8
概述
對于 Spring
和 SpringBoot
到底有什么區(qū)別,我聽到了很多答案,剛開始邁入學(xué)習(xí) SpringBoot
的我當(dāng)時也是一頭霧水,隨著經(jīng)驗的積累、我慢慢理解了這兩個框架到底有什么區(qū)別,相信對于用了 SpringBoot
很久的同學(xué)來說,還不是很理解 SpringBoot
到底和 Spring
有什么區(qū)別,看完文章中的比較,或許你有了不同的答案和看法!
什么是Spring
作為 Java
開發(fā)人員,大家都 Spring
都不陌生,簡而言之, Spring
框架為開發(fā) Java
應(yīng)用程序提供了全面的基礎(chǔ)架構(gòu)支持。它包含一些很好的功能,如依賴注入和開箱即用的模塊,如:
SpringJDBC、SpringMVC、SpringSecurity、SpringAOP、SpringORM、SpringTest
,這些模塊縮短應(yīng)用程序的開發(fā)時間,提高了應(yīng)用開發(fā)的效率例如,在 JavaWeb
開發(fā)的早期階段,我們需要編寫大量的代碼來將記錄插入到數(shù)據(jù)庫中。但是通過使用 SpringJDBC
模塊的 JDBCTemplate
,我們可以將操作簡化為幾行代碼。
什么是Spring Boot
SpringBoot
基本上是 Spring
框架的擴展,它消除了設(shè)置 Spring
應(yīng)用程序所需的 XML配置
,為更快,更高效的開發(fā)生態(tài)系統(tǒng)鋪平了道路。
SpringBoot
中的一些特征:
1、創(chuàng)建獨立的 Spring
應(yīng)用。
2、嵌入式 Tomcat
、 Jetty
、 Undertow
容器(無需部署war文件)。
3、提供的 starters
簡化構(gòu)建配置
4、盡可能自動配置 spring
應(yīng)用。
5、提供生產(chǎn)指標(biāo),例如指標(biāo)、健壯檢查和外部化配置
6、完全沒有代碼生成和 XML
配置要求
從配置分析
Maven依賴
首先,讓我們看一下使用Spring創(chuàng)建Web應(yīng)用程序所需的最小依賴項
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.1.0.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.0.RELEASE</version>
</dependency>
與Spring不同,Spring Boot只需要一個依賴項來啟動和運行Web應(yīng)用程序:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.0.6.RELEASE</version>
</dependency>
在進(jìn)行構(gòu)建期間,所有其他依賴項將自動添加到項目中。
另一個很好的例子就是測試庫。我們通常使用 SpringTest
, JUnit
, Hamcrest
和 Mockito
庫。在 Spring
項目中,我們應(yīng)該將所有這些庫添加為依賴項。但是在 SpringBoot中
,我們只需要添加 spring-boot-starter-test
依賴項來自動包含這些庫。
Spring Boot為不同的Spring模塊提供了許多依賴項。一些最常用的是:
spring-boot-starter-data-jpa
spring-boot-starter-security
spring-boot-starter-test
spring-boot-starter-web
spring-boot-starter-thymeleaf
有關(guān) starter
的完整列表,請查看Spring文檔。
MVC配置
讓我們來看一下 Spring
和 SpringBoot
創(chuàng)建 JSPWeb
應(yīng)用程序所需的配置。
Spring
需要定義調(diào)度程序 servlet
,映射和其他支持配置。我們可以使用 web.xml
文件或 Initializer
類來完成此操作:
public class MyWebAppInitializer implements WebApplicationInitializer {
@Override
public void onStartup(ServletContext container) {
AnnotationConfigWebApplicationContext context = new AnnotationConfigWebApplicationContext();
context.setConfigLocation("com.pingfangushi");
container.addListener(new ContextLoaderListener(context));
ServletRegistration.Dynamic dispatcher = container
.addServlet("dispatcher", new DispatcherServlet(context));
dispatcher.setLoadOnStartup(1);
dispatcher.addMapping("/");
}
}
還需要將 @EnableWebMvc
注釋添加到 @Configuration
類,并定義一個視圖解析器來解析從控制器返回的視圖:
@EnableWebMvc
@Configuration
public class ClientWebConfig implements WebMvcConfigurer {
@Bean
public ViewResolver viewResolver() {
InternalResourceViewResolver bean
= new InternalResourceViewResolver();
bean.setViewClass(JstlView.class);
bean.setPrefix("/WEB-INF/view/");
bean.setSuffix(".jsp");
return bean;
}
}
再來看 SpringBoot
一旦我們添加了 Web
啟動程序, SpringBoot
只需要在 application
配置文件中配置幾個屬性來完成如上操作:
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
上面的所有Spring配置都是通過一個名為auto-configuration的過程添加 Bootweb starter
來自動包含的。
這意味著 SpringBoot
將查看應(yīng)用程序中存在的依賴項,屬性和 bean
,并根據(jù)這些依賴項,對屬性和 bean
進(jìn)行配置。當(dāng)然,如果我們想要添加自己的自定義配置,那么 SpringBoot
自動配置將會退回。
配置模板引擎
現(xiàn)在我們來看下如何在Spring和Spring Boot中配置Thymeleaf模板引擎。
在 Spring
中,我們需要為視圖解析器添加 thymeleaf-spring5
依賴項和一些配置:
@Configuration
@EnableWebMvc
public class MvcWebConfig implements WebMvcConfigurer {
@Autowired
private ApplicationContext applicationContext;
@Bean
public SpringResourceTemplateResolver templateResolver() {
SpringResourceTemplateResolver templateResolver = new SpringResourceTemplateResolver();
templateResolver.setApplicationContext(applicationContext);
templateResolver.setPrefix("/WEB-INF/views/");
templateResolver.setSuffix(".html");
return templateResolver;
}
@Bean
public SpringTemplateEngine templateEngine() {
SpringTemplateEngine templateEngine = new SpringTemplateEngine();
templateEngine.setTemplateResolver(templateResolver());
templateEngine.setEnableSpringELCompiler(true);
return templateEngine;
}
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
ThymeleafViewResolver resolver = new ThymeleafViewResolver();
resolver.setTemplateEngine(templateEngine());
registry.viewResolver(resolver);
}
}
SpringBoot1X
只需要 spring-boot-starter-thymeleaf
的依賴項來啟用 Web
應(yīng)用程序中的 Thymeleaf
支持。??但是由于 Thymeleaf3.0
中的新功能,我們必須將 thymeleaf-layout-dialect
添加為 SpringBoot2X
Web應(yīng)用程序中的依賴項。配置好依賴,我們就可以將模板添加到 src/main/resources/templates
文件夾中, SpringBoot
將自動顯示它們。
Spring Security 配置
為簡單起見,我們使用框架默認(rèn)的 HTTPBasic
身份驗證。讓我們首先看一下使用 Spring
啟用 Security
所需的依賴關(guān)系和配置。
Spring
首先需要依賴 spring-security-web
和 spring-security-config
模塊。接下來, 我們需要添加一個擴展 WebSecurityConfigurerAdapter
的類,并使用 @EnableWebSecurity
注解:
@Configuration
@EnableWebSecurity
public class CustomWebSecurityConfigurerAdapter extends WebSecurityConfigurerAdapter {
@Autowired
public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
auth.inMemoryAuthentication()
.withUser("admin")
.password(passwordEncoder()
.encode("password"))
.authorities("ROLE_ADMIN");
}
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests()
.anyRequest().authenticated()
.and()
.httpBasic();
}
@Bean
public PasswordEncoder passwordEncoder() {
return new BCryptPasswordEncoder();
}
}
這里我們使用 inMemoryAuthentication
來設(shè)置身份驗證。同樣, SpringBoot
也需要這些依賴項才能使其工作。但是我們只需要定義 spring-boot-starter-security
的依賴關(guān)系,因為這會自動將所有相關(guān)的依賴項添加到類路徑中。
SpringBoot
中的安全配置與上面的相同 。
應(yīng)用程序啟動引導(dǎo)配置
Spring
和 SpringBoot
中應(yīng)用程序引導(dǎo)的基本區(qū)別在于 servlet
。Spring
使用 web.xml
或 SpringServletContainerInitializer
作為其引導(dǎo)入口點。SpringBoot
僅使用 Servlet3
功能來引導(dǎo)應(yīng)用程序,下面讓我們詳細(xì)來了解下
Spring 引導(dǎo)配置
Spring
支持傳統(tǒng)的 web.xml
引導(dǎo)方式以及最新的 Servlet3+
方法。
配置 web.xml
方法啟動的步驟
Servlet
容器(服務(wù)器)讀取 web.xml
web.xml
中定義的 DispatcherServlet
由容器實例化
DispatcherServlet
通過讀取 WEB-INF/{servletName}-servlet.xml
來創(chuàng)建 WebApplicationContext
。最后, DispatcherServlet
注冊在應(yīng)用程序上下文中定義的 bean
使用 Servlet3+
方法的 Spring
啟動步驟
容器搜索實現(xiàn) ServletContainerInitializer
的類并執(zhí)行 SpringServletContainerInitializer
找到實現(xiàn)所有類 WebApplicationInitializer``WebApplicationInitializer
創(chuàng)建具有XML或上下文 @Configuration
類 WebApplicationInitializer
創(chuàng)建 DispatcherServlet
與先前創(chuàng)建的上下文。
SpringBoot 引導(dǎo)配置
Spring Boot應(yīng)用程序的入口點是使用@SpringBootApplication注釋的類
@SpringBootApplication
public class Application {
public static void main(String[] args) {
SpringApplication.run(Application.class, args);
}
}
默認(rèn)情況下, SpringBoot
使用嵌入式容器來運行應(yīng)用程序。在這種情況下, SpringBoot
使用 publicstaticvoidmain
入口點來啟動嵌入式 Web
服務(wù)器。此外,它還負(fù)責(zé)將 Servlet
, Filter
和 ServletContextInitializerbean
從應(yīng)用程序上下文綁定到嵌入式 servlet
容器。SpringBoot
的另一個特性是它會自動掃描同一個包中的所有類或 Main
類的子包中的組件。
SpringBoot
提供了將其部署到外部容器的方式。我們只需要擴展 SpringBootServletInitializer
即可:
/**
* War部署
*
* @author SanLi
* Created by 2689170096@qq.com on 2018/4/15
*/
public class ServletInitializer extends SpringBootServletInitializer {
@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(Application.class);
}
@Override
public void onStartup(ServletContext servletContext) throws ServletException {
super.onStartup(servletContext);
servletContext.addListener(new HttpSessionEventPublisher());
}
}
這里外部 servlet
容器查找在war包下的 META-INF
文件夾下MANIFEST.MF文件中定義的 Main-class
, SpringBootServletInitializer
將負(fù)責(zé)綁定 Servlet
, Filter
和 ServletContextInitializer
。
打包和部署
最后,讓我們看看如何打包和部署應(yīng)用程序。這兩個框架都支持 Maven
和 Gradle
等通用包管理技術(shù)。但是在部署方面,這些框架差異很大。例如,Spring Boot Maven插件在 Maven
中提供 SpringBoot
支持。它還允許打包可執(zhí)行 jar
或 war
包并 就地
運行應(yīng)用程序。
在部署環(huán)境中 SpringBoot
對比 Spring
的一些優(yōu)點包括:
1、提供嵌入式容器支持
2、使用命令java -jar獨立運行jar
3、在外部容器中部署時,可以選擇排除依賴關(guān)系以避免潛在的jar沖突
4、部署時靈活指定配置文件的選項
5、用于集成測試的隨機端口生成
結(jié)論
簡而言之,我們可以說 SpringBoot
只是 Spring
本身的擴展,使開發(fā),測試和部署更加方便。
特別推薦一個分享架構(gòu)+算法的優(yōu)質(zhì)內(nèi)容,還沒關(guān)注的小伙伴,可以長按關(guān)注一下:
長按訂閱更多精彩▼
如有收獲,點個在看,誠摯感謝
免責(zé)聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!