1.什么是Spring Boot?
多年来,随着新功能的增加,spring变得越来越复杂。只需要访问https://spring.io/projects页面,我们就可以看到应用程序中使用的所有Spring项目的不同功能。
如果必须启动一个新的Spring项目,我们就要添加构建路径或添加Maven依赖关系,配置应用程序服务器。添加spring配置。
因此,开始一个新的spring项目需要很多操作,因为我们必须从头到尾开始做所有事情。
SpringBoot是解决这个问题的方法。Springboot已经建立在现有的Spring框架之上。使用spring启动,这样就避免了之前我们必须做的所有样板代码和配置。
因此,SpringBoot可以帮助我们以最少的工足量,更加健壮地使用现有的Spring功能。
2.Spring Boot有哪些优点?
- 减少开发,测试时间和努力。
- 使用JavaConfig有助于避免使用XML。
- 避免大量的Maven导入和各种版本冲突。
- 提供意见发展方法。
- 通过提供默认值快速开始开发。
- 没有单独的WEB服务器需要。这意味着你不再需要启动Tomcat,Classfish或其他任何东西。
- 需要更少的配置。因为没有web.xml文件。只需添加用@Configuration注释的类,然后添加用
@Bean注释的方法,Spring将自动加载对象并像以前一样对其中管理。你甚至可以将@Authorware添加到bean方法中,使Spring自动装入需要的依赖关系。
- 基于环境的配置使用这些属性,你可以将你正在使用的环境传递到应用程序:
Dspring.profile.active = {environment}。在加载主应用程序属性文件后,Spring将在(application{environment}.properties)中加载后续的应用程序属性文件。
3.什么是JavaConfig?
spring JavaConfig是Spring社区的产品,他提供了配置Spring Ioc容器的纯Java方法。因此它有助于避免使用XML配置。使用JavaConfig的优点在于:
面向对象的配置。由于配置被定义为JavaConfig中的类,因此用户可以充分利用java中的面向对对象功能。一个配置类可以继承另一个,重写它的@Bean方法等。
减少或消除XML配置。基于依赖注入原则的外化配置的好处已经被证明。但是许多开发人员不希望在XML和java之间来回切换。
JavaConfig为开发人员提供了一种纯java方法来配置XML配置概念相似的Spring容器。
从技术的角度来讲,只使用JavaConfig配置类来配置容器是可行的,但实际上很多人认为将JavaConfig与XML混合配置是理想的。
类型安全和重构友好。JavaConfig提供了一种类型安全的方法来配置Spring容器。由于java5.0对泛型的支持,现在可以按类型而不是按名称检索bean,不需要任何强制转换或基于字符串的查找。
4.如何重新加载SpringBoot上的更改,而无需重新启动服务器?
这可以使用DEV工具来实现。通过这种依赖关系,您可以节省任何更改,嵌入式Tomcat将重新启动。
SpringBoot有一个开发工具(DevTools)模块,它有助于提高开发人员的生产力。Java开发人员面临的一个主要挑战是将文件更改自动部署到服务器并自动启动服务器。
开发人员可以重新加载Springboot上的更改,而无需重新启动服务器。这将消除每次手动部署更改的需要。SpringBoot再发布它的第一个版本的时候没有这个功能。
这是开发人员最需要的功能。DevTool模块完全满足开发人员的需求。该模块将在生产环境中被禁用。它还提供H2数据库控制台以更好地测试应用程序。
<dependency>
<groupId> org.springframework.boot </groupId>
<artifactId> spring-boot-devtools </artifactId>
<optional> true </optional>
</dependency>
5.SpringBoot中的监视器是什么?
Springboot actuator是spring启动框架中的重要功能之一。springboot监视器可以帮助你访问生产环境中正在运行的应用程序的当前状态。
有几个指标必须在生产环境中进行检查和监控。即使一些外部应用程序可能正在使用这些服务来向相关人员出阿发警报消息。监视器模块公开了一组可直接作为HTTP URL访问的REST端点来检查状态。
6.如何在SpringBoot中禁用Actuator端点安全性?
默认情况下,所有敏感的HTTP端点都是安全的,只有具有ACTUATOR角色的用户才能够访问它们。
安全性是使用标准的HTTPServletRequest.isUserInRole方法实施的。我们可以使用management,security.enabled = false来禁用安全性。只有在执行机构端点在防火墙后访问时,才建议禁用安全性。
如何在自定义端口上运行SpringBoot应用程序?
为了在自定义端口上运行SpringBoot应用程序,你可以在application.properties中指定端口
server.port = 8090
7.什么是YAML
YAML是一种人类可读的数据序列化语言。他通常用于配置文件。
与属性文件相比,如果我们想要在配置文件中添加复杂的属性,YAML文件就更加结构化,而且更少混淆。可以看出YAML具有分层配置数据。
8.如何实现SpringBoot应用程序的安全性?
为了实现SpringBoot的安全性,我们使用spring-boot-starter-security依赖项,并且必须添加安全配置。它只需要很少的代码。配置类将必须扩展WebSecrityConfigurerAdapter并覆盖其方法。
9.如何集成SpringBoot和ActiveMQ?
对于集成SpringBoot和ActiveMQ,我们使用spring-boot-starter-activemq依赖关系。他只需要很少的配置,并且不需要样板代码。
10.如何使用SpringBoot实现分页和排序
使用SpringBoot实现分页非常简单。使用Soring Data-JPA可以实现将可分业的org.springframework.data.domain.Pageable传递给存储库方法。