多年来,随着新功能的增加, spring 变得越来越复杂。只需访问 https://spring.io/projects 页面,我们就会看到可以在我们的应用程序中使用的所有 Spring 项目的不同功能。如果必 须启动一个新的 Spring 项目,我们必须添加构建路径或添加 Maven 依赖关系,配置应用程 序服务器,添加 spring 配置。因此,开始一个新的 spring 项目需要很多努力,因为我们现 在必须从头开始做所有事情。 Spring Boot 是解决这个问题的方法。 Spring Boot 已经建立在现有 spring 框架之上。使用 spring 启动,我们避免了之前我们必须做的所有样板代码和配置。因此, Spring Boot 可以 帮助我们以最少的工作量,更加健壮地使用现有的 Spring 功能。
减少开发,测试时间和努力。 使用 JavaConfig 有助于避免使用 XML 。 避免大量的 Maven 导入和各种版本冲突。 提供意见发展方法。 通过提供默认值快速开始开发。 没有单独的 Web 服务器需要。这意味着你不再需要启动 Tomcat , Glassfish 或其他任何东 西。 需要更少的配置 因为没有 web.xml 文件。只需添加用 @ Configuration 注释的类,然后添加 用 @Bean 注释的方法, Spring 将自动加载对象并像以前一样对其进行管理。您甚至可以将 @Autowired 添加到 bean 方法中,以使 Spring 自动装入需要的依赖关系中。 基于环境的配置 使用这些属性,您可以将您正在使用的环境传递到应用程序: - Dspring.profiles.active = {enviornment} 。在加载主应用程序属性文件后, Spring 将在 ( application{environment} .properties )中加载后续的应用程序属性文件。
Spring JavaConfig 是 Spring 社区的产品,它提供了配置 Spring IoC 容器的纯 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 数据库控制台以更好地测试应用程序。 org.springframework.boot spring-boot-devtools true
Spring boot actuator 是 spring 启动框架中的重要功能之一。 Spring boot 监视器可帮助您访 问生产环境中正在运行的应用程序的当前状态。有几个指标必须在生产环境中进行检查和 监控。即使一些外部应用程序可能正在使用这些服务来向相关人员触发警报消息。监视器 模块公开了一组可直接作为 HTTP URL 访问的 REST 端点来检查状态。
YAML 是一种人类可读的数据序列化语言。它通常用于配置文件。 与属性文件相比,如果我们想要在配置文件中添加复杂的属性, YAML 文件就更加结构 化,而且更少混淆。可以看出 YAML 具有分层配置数据。
Spring Profiles 允许用户根据配置文件( dev , test , prod 等)来注册 bean 。因此,当应用 程序在开发中运行时,只有某些 bean 可以加载,而在 PRODUCTION 中,某些其他 bean 可以加载。假设我们的要求是 Swagger 文档仅适用于 QA 环境,并且禁用所有其他文档。这 可以使用配置文件来完成。 Spring Boot 使得使用配置文件非常简单。
CSRF 代表跨站请求伪造。这是一种攻击,迫使最终用户在当前通过身份验证的 Web 应用 程序上执行不需要的操作。 CSRF 攻击专门针对状态改变请求,而不是数据窃取,因为攻击 者无法查看对伪造请求的响应。
在软件开发过程中,跨越应用程序多个点的功能称为交叉问题。这些交叉问题与应用程序 的主要业务逻辑不同。因此,将这些横切关注与业务逻辑分开是面向方面编程( AOP )的 地方。
WebSocket 是一种计算机通信协议,通过单个 TCP 连接提供全双工通信信道。 WebSocket 是双向的 - 使用 WebSocket 客户端或服务器可以发起消息发送。 WebSocket 是全双工的 - 客户端和服务器通信是相互独立的。 单个 TCP 连接 - 初始连接使用 HTTP ,然后将此连接升级到基于套接字的连接。然后这个单 一连接用于所有未来的通信 Light - 与 http 相比, WebSocket 消息数据交换要轻得多。