- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Spring和SpringBoot最核心的3大区别,详解!由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
概述 。
对于 Spring和 SpringBoot到底有什么区别,我听到了很多答案,刚开始迈入学习 SpringBoot的我当时也是一头雾水,随着经验的积累、我慢慢理解了这两个框架到底有什么区别,相信对于用了 SpringBoot很久的同学来说,还不是很理解 SpringBoot到底和 Spring有什么区别,看完文章中的比较,或许你有了不同的答案和看法! 。
什么是Spring 。
作为 Java开发人员,大家都 Spring都不陌生,简而言之, Spring框架为开发 Java应用程序提供了全面的基础架构支持。它包含一些很好的功能,如依赖注入和开箱即用的模块,如:
SpringJDBC、SpringMVC、SpringSecurity、SpringAOP、SpringORM、SpringTest,这些模块缩短应用程序的开发时间,提高了应用开发的效率例如,在 JavaWeb开发的早期阶段,我们需要编写大量的代码来将记录插入到数据库中。但是通过使用 SpringJDBC模块的 JDBCTemplate,我们可以将操作简化为几行代码.
什么是Spring Boot 。
SpringBoot基本上是 Spring框架的扩展,它消除了设置 Spring应用程序所需的 XML配置,为更快,更高效的开发生态系统铺平了道路.
SpringBoot中的一些特征:
1、创建独立的 Spring应用.
2、嵌入式 Tomcat、 Jetty、 Undertow容器(无需部署war文件).
3、提供的 starters 简化构建配置 。
4、尽可能自动配置 spring应用.
5、提供生产指标,例如指标、健壮检查和外部化配置 。
6、完全没有代码生成和 XML配置要求 。
从配置分析 。
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> 。
在进行构建期间,所有其他依赖项将自动添加到项目中.
另一个很好的例子就是测试库。我们通常使用 SpringTest, JUnit, Hamcrest和 Mockito库。在 Spring项目中,我们应该将所有这些库添加为依赖项。但是在 SpringBoot中,我们只需要添加 spring-boot-starter-test依赖项来自动包含这些库.
Spring Boot为不同的Spring模块提供了许多依赖项。一些最常用的是:
spring-boot-starter-data-jpaspring-boot-starter-securityspring-boot-starter-testspring-boot-starter-webspring-boot-starter-thymeleaf 。
有关 starter的完整列表,请查看Spring文档.
MVC配置 。
让我们来看一下 Spring和 SpringBoot创建 JSPWeb应用程序所需的配置.
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; 。
} 。
} 。
再来看 SpringBoot一旦我们添加了 Web启动程序, SpringBoot只需要在 application配置文件中配置几个属性来完成如上操作:
spring.mvc.view.prefix=/WEB-INF/jsp/ 。
spring.mvc.view.suffix=.jsp 。
上面的所有Spring配置都是通过一个名为auto-configuration的过程添加 Bootweb starter来自动包含的.
这意味着 SpringBoot将查看应用程序中存在的依赖项,属性和 bean,并根据这些依赖项,对属性和 bean进行配置。当然,如果我们想要添加自己的自定义配置,那么 SpringBoot自动配置将会退回.
配置模板引擎 。
现在我们来看下如何在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 添加为 SpringBoot2XWeb应用程序中的依赖项。配置好依赖,我们就可以将模板添加到 src/main/resources/templates文件夹中, SpringBoot将自动显示它们.
Spring Security 配置 。
为简单起见,我们使用框架默认的 HTTPBasic身份验证。让我们首先看一下使用 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来设置身份验证。同样, SpringBoot也需要这些依赖项才能使其工作。但是我们只需要定义 spring-boot-starter-security的依赖关系,因为这会自动将所有相关的依赖项添加到类路径中.
SpringBoot中的安全配置与上面的相同 .
应用程序启动引导配置 。
Spring和 SpringBoot中应用程序引导的基本区别在于 servlet。Spring使用 web.xml 或 SpringServletContainerInitializer作为其引导入口点。SpringBoot仅使用 Servlet3功能来引导应用程序,下面让我们详细来了解下 。
Spring 引导配置 。
Spring支持传统的 web.xml引导方式以及最新的 Servlet3+方法.
配置 web.xml方法启动的步骤 。
Servlet容器(服务器)读取 web.xml 。
web.xml中定义的 DispatcherServlet由容器实例化 。
DispatcherServlet通过读取 WEB-INF/{servletName}-servlet.xml来创建 WebApplicationContext。最后, DispatcherServlet注册在应用程序上下文中定义的 bean 。
使用 Servlet3+方法的 Spring启动步骤 。
容器搜索实现 ServletContainerInitializer的类并执行 SpringServletContainerInitializer找到实现所有类 WebApplicationInitializer``WebApplicationInitializer创建具有XML或上下文 @Configuration类 WebApplicationInitializer创建 DispatcherServlet与先前创建的上下文.
SpringBoot 引导配置 。
Spring Boot应用程序的入口点是使用@SpringBootApplication注释的类 。
@SpringBootApplication 。
public class Application { 。
public static void main(String[] args) { 。
SpringApplication.run(Application.class, args); 。
} 。
} 。
默认情况下, SpringBoot使用嵌入式容器来运行应用程序。在这种情况下, SpringBoot使用 publicstaticvoidmain入口点来启动嵌入式 Web服务器。此外,它还负责将 Servlet, Filter和 ServletContextInitializerbean从应用程序上下文绑定到嵌入式 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将负责绑定 Servlet, Filter和 ServletContextInitializer.
打包和部署 。
最后,让我们看看如何打包和部署应用程序。这两个框架都支持 Maven和 Gradle等通用包管理技术。但是在部署方面,这些框架差异很大。例如,Spring Boot Maven插件在 Maven中提供 SpringBoot支持。它还允许打包可执行 jar或 war包并 就地运行应用程序.
在部署环境中 SpringBoot 对比 Spring的一些优点包括:
1、提供嵌入式容器支持 。
2、使用命令java -jar独立运行jar 。
3、在外部容器中部署时,可以选择排除依赖关系以避免潜在的jar冲突 。
4、部署时灵活指定配置文件的选项 。
5、用于集成测试的随机端口生成 。
结论 。
简而言之,我们可以说 SpringBoot只是 Spring本身的扩展,使开发,测试和部署更加方便.
最后此篇关于Spring和SpringBoot最核心的3大区别,详解!的文章就讲到这里了,如果你想了解更多关于Spring和SpringBoot最核心的3大区别,详解!的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
Linux 有许多跨(假设是 2 个)CPU 内核执行的线程和进程。我希望我的单线程 C/C++ 应用程序成为 CPU0 上的唯一线程。我如何“移动”所有其他线程以使用 CPU1? 我知道我可以使用
我有一个类似于下图的数据库表 Table with 2 columns (UserId and value) 我将传递 UserId 和 2 个字符串。例如:userId: 1, key1: h1,
我想在我的新项目中使用 ASP.NET Core,因为我听说它更快。但是,该项目将使用广泛的数据库访问功能,Entity Framework Core 不支持其中一些功能。我想知道,是否可以使用 En
我已经使用 EntityFrameworkCore.SqlServer 2.0 开发了 asp .net core wep api 2.0 应用程序。它是使用数据库优先方法开发的。当尝试使用 dbco
我已经阅读了很多关于这个主题的文章,但我仍然无法处理这个问题。对不起,如果它是重复的,无论如何! 所以基本上,我正在从头开始构建一个 Angular 应用程序,并且我想按照最佳约定来组织我的代码。我有
我对MPI还是陌生的,所以如果这是一个琐碎的问题,请原谅我。我有一个四核CPU。我想运行一个在单个内核上使用两个进程的OpenMPI C++程序。有什么办法吗?如果是这样,那又如何?我提到了this
下面是一个传播异常处理机制的类问题,所需的输出是异常。任何人都可以解释为什么输出是异常,在此先感谢。 Class Question { public void m1() throws Excep
我想打印每个获得 CPU 时间片的进程的 name 和 pid。可能吗? 最佳答案 对于单个流程,您可以在以下位置获取此信息: /proc//stat 第14和第15个字段分别代表在用户态和内核态花费
我想知道是否可以识别具有特定 thread-id 的线程使用的物理处理器(核心)? 例如,我有一个多线程应用程序,它有两 (2) 个线程(例如,thread-id = 10 和 thread-id =
我有一个需要身份验证的 Solr 核心。假设我有一个用户,密码为password。当我现在尝试在控制台中创建一个 Solr 核心时 bin\solr create -c test 我收到 HTTP 错
我想为与使用它的项目不同的类库中的第二个和后续数据库创建迁移。有皱纹。我永远不会知道连接字符串,直到用户登录并且我可以从目录数据库 (saas) 中获取它。 对于目录数据库,我使用了来自 this 的
我想为一种可以产生 GHC Core 的简单语言创建一个前端。然后我想获取这个输出并通过正常的 GHC 管道运行它。根据this page , 不能直接通过 ghc 命令实现。我想知道是否有任何方法可
阅读文档,我构建了 2 个使用 BLE 连接 2 个 iDevices 的应用程序。 一个设备是中央设备,另一个是外围设备。 Central在寻找Peripheral,当找到它时,探索它的服务和特性,
在我的网络应用程序中,我对长时间运行的任务进行了操作,我想在后台调用此任务。因此,根据文档 .net core 3.1 Queued background tasks我为此使用这样的代码: publi
Solr 1.4 Enterprise Search Server 建议对核心副本进行大量更新,然后将其换成主核心。我正在按照以下步骤操作: 创建准备核心:http://localhost:8983/
它们是否存在,如果存在,文档和代码在哪里? 最佳答案 它们位于 Git 的 test 目录中。 https://github.com/jquery/jquery/tree/master/test 关于
我有一个 Lisp (SBCL 1.0.40.0.debian) 应用程序 (myfitnessdata),它使用以下代码来处理命令行参数: (:use :common-lisp) (:export
Core是GHC的中间语言。阅读Core可以帮助你更好地了解程序的性能。有人向我索要有关阅读 Core 的文档或教程,但我找不到太多。 有哪些文档可用于阅读 GHC Core? 这是我迄今为止发现的内
我有一个核心 WebJob 部署到 Azure Web 应用程序中。我正在使用WebJobs version 3.0.6 . 我注意到,WebJob 代码不会立即拾取对连接字符串和应用程序设置的更改(
我有一个在内部构造和使用 SqlConnection 类的第三方库。我可以从该类继承,但它有大量重载,到目前为止我一直无法找到合适的重载。我想要的是将参数附加到正在使用的连接字符串。 有没有办法在 .
我是一名优秀的程序员,十分优秀!