对于 Spring
和 SpringBoot
到底有什么区别,我听到了很多答案,刚开始迈入学习 SpringBoot
的我当时也是一头雾水,随着经验的积累、我慢慢理解了这两个框架到底有什么区别,我相信对于用了 SpringBoot
很久的开发人员来说,有绝大部分还不是很理解 SpringBoot
到底和 Spring
有什么区别,看完文章中的比较,或许你有了不同的答案和看法!
先来聊一聊 Spring
作为 Java
开发人员,大家都 Spring
可不陌生,简而言之, Spring
框架为开发 Java
应用程序提供了全面的基础架构支持。它包含一些很好的功能,如依赖注入和开箱即用的模块,如:
Spring JDBC 、Spring MVC 、Spring Security、 Spring AOP 、Spring ORM 、Spring Test
这些模块大家应该都用过吧,这些模块缩短应用程序的开发时间,提高了应用开发的效率
例如,在 Java Web
开发的早期阶段,我们需要编写大量的代码来将记录插入到数据源中。但是通过使用 Spring JDBC
模块的 JDBCTemplate
,我们可以将这操作简化为只需配置几行代码。
Spring Boot
基本上是 Spring
框架的扩展,它消除了设置 Spring
应用程序所需的 XML配置
,为更快,更高效的开发生态系统铺平了道路。
以下是 Spring Boot
中的一些特点:
1:创建独立的 spring
应用。
2:嵌入 Tomcat
, Jetty
Undertow
而且不需要部署他们。
3:提供的“starters” poms来简化 Maven
配置
4:尽可能自动配置 spring
应用。
5:提供生产指标,健壮检查和外部化配置
6:绝对没有代码生成和 XML
配置要求
4.1、 Maven依赖
首先,让我们看一下使用Spring创建Web应用程序所需的最小依赖项
<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应用程序:
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> <version>2.0.6.RELEASE</version> </dependency>
在进行构建期间,所有其他依赖项将自动添加到项目中。
另一个很好的例子就是测试库。我们通常使用 Spring Test
, JUnit
, Hamcrest
和 Mockito
库。在 Spring
项目中,我们应该将所有这些库添加为依赖项。但是在 Spring Boot中
,我们只需要添加 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
4.2、MVC配置
让我们来看一下 Spring
和 Spring Boot
创建 JSP Web
应用程序所需的配置。
Spring
需要定义调度程序 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; } }
和上述操作一比,一旦我们添加了 Web
启动程序, Spring Boot
只需要在 application
配置文件中配置几个属性来完成如上操作:
spring.mvc.view.prefix=/WEB-INF/jsp/ spring.mvc.view.suffix=.jsp
上面的所有Spring配置都是通过一个名为auto-configuration的过程添加 Boot web starter
来自动包含的。
这意味着 Spring Boot
将查看应用程序中存在的依赖项,属性和 bean
,并根据这些依赖项,对属性和 bean
进行配置。当然,如果我们想要添加自己的自定义配置,那么 Spring Boot
自动配置将会退回。
4.3、配置模板引擎
现在我们来看下如何在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
应用程序中的 Thymeleaf
支持。但是由于 Thymeleaf3.0
中的新功能, 我们必须将 thymeleaf-layout-dialect
添加 为 SpringBoot2X
Web应用程序中的依赖项。一旦依赖关系到位,我们就可以将模板添加到 src/main/resources/templates
文件夹中, SpringBoot
将自动显示它们。
4.4、Spring Security 配置
为简单起见,我们使用框架默认的 HTTP Basic
身份验证。让我们首先看一下使用 Spring
启用 Security
所需的依赖关系和配置。
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
来设置身份验证。同样, Spring Boot
也需要这些依赖项才能使其工作。但是我们只需要定义 spring-boot-starter-security
的依赖关系,因为这会自动将所有相关的依赖项添加到类路径中。
Spring Boot
中的安全配置与上面的相同。
Spring
和 Spring Boot
中应用程序引导的基本区别在于 servlet
。
Spring
使用 web.xml
或 SpringServletContainerInitializer
作为其引导入口点。
Spring Boot
仅使用 Servlet 3
功能来引导应用程序,下面让我们详细来了解下
5.1、Spring 是怎样引导配置的呢?
Spring
支持传统的 web.xml
引导方式以及最新的 Servlet 3+
方法。
让我们看一下 web.xml
方法的步骤:
Servlet
容器(服务器)读取 web.xml
web.xml
中定义的 DispatcherServlet
由容器实例化
DispatcherServlet
通过读取 WEB-INF / {servletName} -servlet.xml
来创建 WebApplicationContext
最后, DispatcherServlet
注册在应用程序上下文中定义的 bean
以下是使用 Servlet 3+
方法的 Spring
引导:
容器搜索实现 ServletContainerInitializer
的类并执行
SpringServletContainerInitializer
找到实现所有类 WebApplicationInitializer
WebApplicationInitializer
创建具有XML或上下文 @Configuration
类
WebApplicationInitializer
创建 DispatcherServlet
的 与先前创建的上下文。
5.2、SpringBoot 有是如何配置的呢?
Spring Boot应用程序的入口点是使用@SpringBootApplication注释的类:
@SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } }
默认情况下, Spring Boot
使用嵌入式容器来运行应用程序。在这种情况下, Spring Boot
使用 public static void main
入口点来启动嵌入式 Web
服务器。此外,它还负责将 Servlet
, Filter
和 ServletContextInitializer bean
从应用程序上下文绑定到嵌入式 servlet
容器。
Spring Boot
的另一个特性是它会自动扫描同一个包中的所有类或 Main
类的子包中的组件。
Spring Boot
提供了将其部署到外部容器的方式。在这种情况下,我们必须扩展 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
将负责绑定 Servlet
, Filter
和 ServletContextInitializer
。
最后,让我们看看如何打包和部署应用程序。这两个框架都支持 Maven
和 Gradle
等通用包管理技术。但是在部署方面,这些框架差异很大。例如,Spring Boot Maven插件在 Maven
中提供 Spring Boot
支持。它还允许打包可执行 jar
或 war
包并 就地
运行应用程序。
在部署环境中 Spring Boot
对比 Spring
的一些优点包括:
简而言之,我们可以说 Spring Boot
只是 Spring
本身的扩展,使开发,测试和部署更加方便。
到此这篇关于Spring和SpringBoot比较及区别解惑的文章就介绍到这了,更多相关Spring和SpringBoot区别内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!
时间:2020-06-21
概述: @Valid是使用Hibernate validation的时候使用 @Validated是只用Spring Validator校验机制使用 说明:java的JSR303声明了@Valid这类接口,而Hibernate-validator对其进行了实现 @Validation对@Valid进行了二次封装,在使用上并没有区别,但在分组.注解位置.嵌套验证等功能上有所不同,这里主要就这几种情况进行说明. 注解位置: @Validated:用在类型.方法和方法参数上.但不能用于成员属性(fie
前言 springmvc中有两种很普遍的AOP实现: 1.过滤器(Filter) 2.拦截器(Interceptor) 本篇面对的是一些刚接触springboot的人群 所以主要讲解filter和interceptor的简单实现和它们之间到底有什么区别 (一些复杂的功能我会之后发出文章,请记得关注) Filter的简单实现 字面意思:过滤器就是过滤的作用,在web开发中过滤一些我们指定的url 那么它能帮我们过滤什么呢? 那功能可就多了: 比如过拦截掉我们不需要的接口请求 修改请求(reques
Q:使用过滤器.拦截器与切片实现每个请求耗时的统计,并比较三者的区别与联系 过滤器Filter 过滤器概念 Filter是J2E中来的,可以看做是 Servlet 的一种"加强版",它主要用于对用户请求进行预处理和后处理,拥有一个典型的 处理链 .Filter也可以对用户请求生成响应,这一点与Servlet相同,但实际上很少会使用Filter向用户请求生成响应.使用Filter完整的流程是:Filter对用户请求进行预处理,接着将请求交给Servlet进行预处理并生成响应,最后Filt
静态页面的return默认是跳转到/static/目录下,当在pom.xml中引入了thymeleaf组件,动态跳转会覆盖默认的静态跳转,默认就会跳转到/templates/下,注意看两者return代码也有区别,动态没有html后缀. 1.1 在static下新建hello1.html 运行程序,浏览器输入http://localhost:8080/hello1.html so,可以在根目录下访问hello1.html,static目录类似于传统Java web中的webroot或webcon
SpringBoot的自动装配是拆箱即用的基础,也是微服务化的前提.这次主要的议题是,来看看它是怎么样实现的,我们透过源代码来把握自动装配的来龙去脉. 一.自动装配过程分析 1.1.关于@SpringBootApplication 我们在编写SpringBoot项目时,@SpringBootApplication是最常见的注解了,我们可以看一下源代码: /* * Copyright 2012-2017 the original author or authors. * * Licensed un
java中的类可以是static吗?答案是可以.在java中我们可以有静态实例变量.静态方法.静态块.类也可以是静态的. java允许我们在一个类里面定义静态类.比如内部类(nested class).把nested class封闭起来的类叫外部类.在java中,我们不能用static修饰顶级类(top level class).只有内部类可以为static. 静态内部类和非静态内部类之间到底有什么不同呢?下面是两者间主要的不同. (1)内部静态类不需要有指向外部类的引用.但非静态内部
static的作用: 1.将对象层级提升为类层级 (即将对象可以调用的,提升为对象和类均可调用的成员): //推荐使用类来调用 ClassNme.静态成员 (包括变量.方法.成员对象) 2.static修饰的成员,在类加载时即准备完成,而不需要创建对象: //类加载只做一次: 类名 的时候会类加载; new 对象时会类加载 3.静态成员方法只能访问静态成员,不能访问非静态成员(因为调用该方法时可能还没有创建对象): 而非静态成员方法既能访问非静态成员,又能访问
本篇浅析java中static的用法,主要五个方面:静态成员变量,静态方法,静态块,静态内部类,静态导包. 首先还是一张表格说一下静态对象和非静态对象的区别: 静态对象 非静态对象 归属 类共同具有 类的各个实例独立拥有 内存分配 内存空间上固定的 附属类分配 分配空间顺序 优先分配静态对象空间 优先分配静态对象空间,初始化也一样 1 静态变量,静态方法,静态块 静态对象,静态方法都是在原对象和方法上加上static关键字修饰,表示类可以直接调用这些,而不需要实例化后再调用.具有的好处是: 1-
关于static和非static变量的区别 1. static 修饰的变量称为类变量或全局变量或成员变量,在类被加载的时候成员变量即被初始化,与类关联,只要类存在,static变量就存在.非static修饰的成员变量是在对象new出来的时候划分存储空间,是与具体的对象绑定的,该成员变量仅为当前对象所拥有的. 2. static修饰的变量在加载的时候先于main方法加载在内存中的数据共享区-------方法区,而非static的变量在加载的时候,是要创建变量才加载在堆内存中的. 3. 一个stat
php中static 静态变量和普通变量的区别 在变量的前面加上static 就构成了静态变量(static 变量). static变量和普通变量的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的. 而静态全局变量则限制了其作用域, 即只在定义该变量的源文件内有效, 在同一源程序的其它源文件中不能使用它.由于静态全局变量的作用域局限于一个源文件内,只能为该源文件内的函数公用, 因此可以避免在其它源文件中引起错误. static变
static主要有三个作用:(1)局部静态变量(2)外部静态变量/函数(3)静态数据成员/成员函数 前两种C和C++都有,第三种仅在C++中有,下面分别作以下介绍: 一.局部静态变量在C/C++中, 局部变量按照存储形式可分为三种auto, static, register.其中register不常用到,下面主要说说auto和static的区别. 1. 存储空间分配和生存周期不同auto类型局部变量就是普通的局部变量(不加修饰的局部变量默认为该类型).该类型局部变量存储在栈上,在动态存储区,生命
使用SSH终端(比如putty,xshell)连接Linux服务器上运行比较耗时任务,可能需要几个小时甚至几天才能完成,这时候终端被占据,我们还要做其他的任务呢,所以需要将这一类耗时任务放到后台来跑,只需要记录好日志就行了,有下面这些常用方法来实现这个需求. command & 在终端输入command &运行,这时候使用Ctrl + C中止命令将会失效,因为对&后台运行SIGINT1信号免疫,程序会继续运行. 但如果你直接关掉终端, 进程将跟着中止. 可见,使用&后台运行
结论:getMeasuredWidth()获取的是view原始的大小,也就是这个view在XML文件中配置或者是代码中设置的大小.getWidth()获取的是这个view最终显示的大小,这个大小有可能等于原始的大小也有可能不等于原始大小. 1.getMeasuredWidth 从源码上来看,getMeasuredWidth()获取的是mMeasuredWidth的这个值.这个值是一个8位的十六进制的数字,高两位表示的是这个measure阶段的Mode的值,具体可以查看MeasureSpec的原理