多年来,随着新功能的增加,spring变得越来越复杂。只需访问 https://spring.io/projects
页面,我们就会看到可以在我们的应用程序中使 用的所有Spring项目的不同功能。如果必须启动一个新的Spring项目, 我们必须添加构建路径或添加Maven依赖关系,配置应用程序服务器, 添加spring配置。因此,开始一个新的spring项目需要很多努力,因为 我们现在必须从头开始做所有事情。
Spring Boot是解决这个问题的方法。Spring Boot已经建立在现有spring 框架之上。使用spring启动,我们避免了之前我们必须做的所有样板代码和配置。因此,Spring Boot可以帮助我们以最少的工作量,更加健壮地使 用现有的Spring功能。
Spring Boot的优点有:
@Configuration
注 释的类,然后添加用@Bean
注释的方法,Spring将自动加载对象并像以 前一样对其进行管理。您甚至可以将@Autowired
添加到bean方法中, 以使Spring自动装入需要的依赖关系中。基于环境的配置使用这些属 性,您可以将您正在使用的环境传递到应用程序:-Dspring.profiles.active = {enviornment}
。在加载主应用程序属性文件后,Spring将在 (application{environment} .properties)中加载后续的应用程序属性文件。Spring JavaConfig是Spring社区的产品,它提供了配置Spring loC容器的纯 Java方法。因此它有助于避免使用XML配置。使用JavaConfig的优点在于:
面向对象的配置。由于配置被定义为JavaConfig中的类,因此用户可以充 分利用Java中的面向对象功能。一个配置类可以继承另一个,重写它的 @Bean方法等。
减少或消除XML配置。基于依赖注入原则的外化配置的好处已被证明。 但是,许多开发人员不希望在XML和Java之间来回切换。
JavaConfig为 开发人员提供了一种纯Java方法来配置与XML配置概念相似的Spring 容器。从技术角度来讲,只使用JavaConfig配置类来配置容器是可行 的,但实际上很多人认为将JavaConfig与XML混合匹配是理想的。类型 安全和重构友好。JavaConfig提供了一种类型安全的方法来配置Spring 容器。由于Java 5.0对泛型的支持,现在可以按类型而不是按名称检索 bean,不需要任何强制转换或基于字符串的查找。
这可以使用DEV工具来实现。通过这种依赖关系,您可以节省任何更,嵌入式tomcat将重新启动。Spring Boot有一个开发工具(DevTools)模块,它有助于提高开发人员的生产力。Java开发人员面临的一个主要挑 战是将文件更改自动部署到服务器并自动重启服务器。开发人员可以重新加载Spring Boot上的更改,而无需重新启动服务器。这将消除每次手动部 署更改的需要。Spring Boot在发布它的第一个版本时没有这个功能。这是开发人员最需要的功能。DevTools模块完全满足开发人员的需求。该模块将在生产环境中被禁用。它还提供H2数据库控制台以更好地测试应用程序。
Spring boot actuator是spring启动框架中的重要功能之一。Spring boot监 视器可帮助您访问生产环境中正在运行的应用程序的当前状态。有几个指 标必须在生产环境中进行检查和监控。即使一些外部应用程序可能正在使 用这些服务来向相关人员触发警报消息。监视器模块公开了一组可直接作为HTTP URL访问的REST端点来检查状态。
默认情况下,所有敏感的HTTP端点都是安全的,只有具有ACTUATOR 角色的用户才能访问它们。安全性是使用标准的
HttpServletRequest.isUserInRole方法实施的。我们可以使用management.security.enabled = false
来禁用安全性。只有在执行机构端点在防火墙后访问时,才建议禁用安全 性。
为了在自定义端口上运行Spring Boot应用程序,您可以在 application.properties中指定端口。
server.port = 8090
YAML是一种人类可读的数据序列化语言。它通常用于配置文件。
与属性文件相比,如果我们想要在配置文件中添加复杂的属性,YAML文 件就更加结构化,而且更少混淆。可以看出YAML具有分层配置数据。
为了实现 Spring Boot的安全性,我们使用 spring-boot-starter-security 依赖 项,并且必须添加安全配置。它只需要很少的代码。配置类将必须扩展 WebSecurityConfigurerAdapter 并覆盖其方法。
对于集成Spring Boot和ActiveMQ,我们使用 spring-boot-starter-activemq
依赖关系。它只需要很少的配置,并且不需要样板代码。
使用Spring Boot实现分页非常简单。使用Spring Data-JPA可以实现将 可分页的 org.springframework.data.domain.Pageable 传递给存储库方法。
Swagger广泛用于可视化API,使用Swagger UI为前端开发人员提供在 线沙箱。Swagger是用于生成RESTful Web服务的可视化表示的工具,规 范和完整框架实现。它使文档能够以与服务器相同的速度更新。当通过 Swagger正确定义时,消费者可以使用最少量的实现逻辑来理解远程服 务并与其进行交互。因此,Swagger消除了调用服务时的猜测。
Spring Profiles允许用户根据配置文件(dev, test, prod等)来注册bean。 因此,当应用程序在开发中运行时,只有某些bean可以加载,而在 PRODUCTION中,某些其他bean可以加载。假设我们的要求是 Swagger文档仅适用于QA环境,并且禁用所有其他文档。这可以使用配 置文件来完成。Spring Boot使得使用配置文件非常简单。
Spring Boot Batch提供可重用的函数,这些函数在处理大量记录时非常重 要,包括日志/跟踪,事务管理,作业处理统计信息,作业重新启动,跳 过和资源管理。它还提供了更先进的技术服务和功能,通过优化和分区技 术,可以实现极高批量和高性能批处理作业。简单以及复杂的大批量批处 理作业可以高度可扩展的方式利用框架处理重要大量的信息。
FreeMarker是一个基于Java的模板引擎,最初专注于使用MVC软件架构 进行动态网页生成。使用Freemarker的主要优点是表示层和业务层的完 全分离。程序员可以处理应用程序代码,而设计人员可以处理html页面 设计。最后使用freemarker可以将这些结合起来,给出最终的输出页面。
Spring提供了一种使用ControllerAdvice处理异常的非常有用的方法。我们 通过实现一个ControlerAdvice类,来处理控制器类抛出的所有异常。
17、您使用了哪些starter maven依赖项? 使用了下面的一些依赖项
spring-boot-starter-activemq spring-boot-starter-security
spring-boot-starter-web这有助于增加更少的依赖关系,并减少版本的冲 突。
CSRF代表跨站请求伪造。这是一种攻击,迫使最终用户在当前通过身份 验证的Web应用程序上执行不需要的操作。CSRF攻击专门针对状态改 变请求,而不是数据窃取,因为攻击者无法查看对伪造请求的响应。
WebSocket是一种计算机通信协议,通过单个TCP连接提供全双工通信 信道。
WebSocket是双向的-使用WebSocket客户端或服务器可以发起消息发 送。
WebSocket是全双工的-客户端和服务器通信是相互独立的。
单个TCP连接-初始连接使用HTTP,然后将此连接升级到基于套接字的连 接。然后这个单一连接用于所有未来的通信
Light -与http相比,WebSocket消息数据交换要轻得多。
在软件开发过程中,跨越应用程序多个点的功能称为交叉问题。这些交叉 问题与应用程序的主要业务逻辑不同。因此,将这些横切关注与业务逻辑 分开是面向方面编程(AOP)的地方。
Apache Kafka是一个分布式发布-订阅消息系统。它是一个可扩展的,容 错的发布-订阅消息系统,它使我们能够构建分布式应用程序。这是一个 Apache顶级项目。Kafka适合离线和在线消息消费。
Spring Boot提供监视器端点以监控各个微服务的度量。这些端点对于获 取有关应用程序的信息(如它们是否已启动)以及它们的组件(如数据库等)是 否正常运行很有帮助。但是,使用监视器的一个主要缺点或困难是,我们 必须单独打开应用程序的知识点以了解其状态或健康状况。想象一下涉及
50个应用程序的微服务,管理员将不得不击中所有50个应用程序的执行 终端。