# Index springboot 开发文档 banner 在 resources 目录下创建 banner.txt 文件,或者banner.gif 文件,springboot 启动时会显示 banner 文件的内容。 ## 配置 src/main/resources/application-dev.properties src/main/resources/application-pro.properties src/main/resources/application-test.properties src/main/resources/application.properties 技术栈 * springboot3.2 * mysql5.7 * Redis * MongoDB * maven 3.5.0 * jdk 11 * tomcat ## Reference ## springboot 版本对比 | Spring Boot 2.x | Spring Boot 3.x | | | :-------------- | :--------------- | ------------------ | | Spring版本 | Spring 5.x | Spring 6.x | | JDK版本 | >= 1.8 | >= 17 | | Tomcat版本 | 9.x | 10.x | | Annotation包 | javax.annotation | jakarta.annotation | | Servlet包 | javax.servlet | jakarta.servlet | | JMS包 | javax.jms | jakarta.jms | | JavaMail包 | javax.mail | jakarta.mail | # 静态资源 css 样式; js 脚本; favicon.ico 图标等; Spring Boot 访问静态资源,默认有两个默认目录: - `classpath/static` 目录:`src/main/resource` - `ServletContext` 根目录下: `src/main/webapp` 这里打包app.jar包后,WEB-INF 下面的 classes 目录为 classpath 配置文件可以更改目录路径: 在 properties 文件里面设置 spring.resources.static-locations 就ok了。 ``` vim application.properties spring.resources.static-locations: classpath:/META-INF/resources/,classpath:/resources/,classpath:/static/,classpath:/public/ spring.mvc.static-path-pattern=/static/** ``` ## 前后端分离 ## 配置日期格式化 要让 Spring Boot 能够按照指定的格式进行日期类型转换,需要做以下步骤: - 定义一个 `MvcConfig` 类,让其实现 `WebMvcConfigurer` 接口; - 重写 `addFormatters` 方法; - 添加一个 `DateFormatter`; ```java package site.exception.springbootdateformat.config; import org.springframework.context.annotation.Configuration; import org.springframework.format.FormatterRegistry; import org.springframework.format.datetime.DateFormatter; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; @Configuration public class MvcConfig implements WebMvcConfigurer { /** * 配置日期格式化 * @param registry */ @Override public void addFormatters(FormatterRegistry registry) { registry.addFormatter(new DateFormatter("yyyy-MM-dd HH:mm:ss")); } } ``` ## 配置跨域 实现 `addCorsMappings` 接口来添加规则来允许跨域访问: ```java package site.exception.config; import org.springframework.web.servlet.config.annotation.CorsRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; public class CORSConfig extends WebMvcConfigurerAdapter { @Override public void addCorsMappings(CorsRegistry registry) { // 允许所有跨域访问 registry.addMapping("/**"); } } ``` `/**` 允许所有域名都能够跨域访问,下面看看更为精细的控制: ```JAVA package site.exception.config; import org.springframework.web.servlet.config.annotation.CorsRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter; /** * @author www.exception.site (exception 教程网) * @date 2019/2/13 * @time 下午8:36 * @discription **/ public class CORSConfig extends WebMvcConfigurerAdapter { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/api/**") .allowedOrigins("http://www.exception.site") .allowedMethods("POST", "GET"); } } ``` 通过上面的配置,只允许来自 [www.exception.site](https://www.exception.site/) 的跨域访问,并且限定只能对 `/api` 下的所有接口进行跨域访问,同时只能访问 `POST` 和 `GET` 方法。 ## Jackson 配置 Jackson 是 Spring Boot 内置的 Json 解析框架,用来完成出入参的序列化和反序列化。通常,我们会在 Controller 类中方法上,加上 @RequestBody 或者 @ResponseBody 注解,Spring Boot 会自动对出入参做 Json 解析与转换工作。 ## 配置 Jetty 默认自带的 tomcat,可以改为jetty 轻量,添加依赖 ```xml org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-tomcat org.springframework.boot spring-boot-starter-jetty ``` ## hello world pom.xml 配置 ``` org.springframework.boot spring-boot-starter-parent 2.1.4.RELEASE 1.8 org.springframework.boot spring-boot-starter org.springframework.boot spring-boot-starter-test test org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-autoconfigure org.springframework.boot spring-boot-maven-plugin ``` # spring boot 介绍 ## 微服务 将一个大系统分割为多个独立的应用,拥有自己的进程。易部署,易扩展。 ## Spring boot ## 它是如何工作的? Spring Boot 使用 **@EnableAutoConfiguration** 注解根据您添加到项目的依赖项自动配置您的应用程序。 例如,如果 MySQL 数据库在你的类路径上,但你没有配置任何数据库连接,那么 Spring Boot 会自动配置一个内存数据库。 Spring Boot 应用程序的入口点是包含 **@SpringBootApplication** 注解的类和 main 方法。 Spring Boot 通过使用 **@ComponentScan** 注解自动扫描项目中包含的所有组件。 ------ ## Spring Boot 启动器 处理依赖管理对于大型项目来说是一项艰巨的任务。 Spring Boot 通过提供一组依赖项方便开发人员解决了这个问题。 例如,如果您想使用 Spring 和 JPA 进行数据库访问,则在项目中包含 **spring-boot-starter-data-jpa** 依赖项就足够了。 请注意,所有 Spring Boot 启动器都遵循相同的命名模式 **spring-boot-starter-** *,其中 * 表示它是应用程序的一种类型。 ### 示例 请查看下面解释的以下 Spring Boot 启动器以更好地理解 − **Spring Boot Starter Actuator 依赖项** 用于监视和管理您的应用程序。 其代码如下所示 − ``` org.springframework.boot spring-boot-starter-actuator ``` **Spring Boot Starter Security 依赖项** 用于 Spring Security。 其代码如下所示 − ``` org.springframework.boot spring-boot-starter-security ``` **Spring Boot Starter web 依赖** 用于编写一个 Rest Endpoints。 其代码如下所示 − ``` org.springframework.boot spring-boot-starter-web ``` **Spring Boot Starter Thyme Leaf 依赖项** 用于创建 Web 应用程序。 其代码如下所示 − ``` org.springframework.boot spring-boot-starter-thymeleaf ``` **Spring Boot Starter Test 依赖项**用于编写测试用例。 其代码如下所示 − ``` org.springframework.boot spring-boot-starter-test ``` ------ ## 自动配置 Spring Boot Auto Configuration 根据您在项目中添加的 JAR 依赖项自动配置您的 Spring 应用程序。 例如,如果 MySQL 数据库在你的类路径上,但你没有配置任何数据库连接,那么 Spring Boot 会自动配置一个内存数据库。 为此,您需要在 main 主类文件中添加 **@EnableAutoConfiguration** 注解或 **@SpringBootApplication** 注解。 然后,您的 Spring Boot 应用程序将被自动配置。 观察以下代码以更好地理解 − ``` import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.EnableAutoConfiguration; @EnableAutoConfiguration public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` ------ ## Spring Boot 应用程序 Spring Boot Application 的入口点是包含 **@SpringBootApplication** 注解的类。 这个类应该有运行 Spring Boot 应用程序的 main 方法。 **@SpringBootApplication** 注解包括自动配置、组件扫描和 Spring Boot 配置。 如果在类中添加了**@SpringBootApplication**注解,则不需要添加**@EnableAutoConfiguration、@ComponentScan**和**@SpringBootConfiguration**注解。 **@SpringBootApplication** 注解包括所有其他注解。 观察以下代码以更好地理解 − ``` import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ``` ------ ## 组件扫描 Spring Boot 应用程序在应用程序初始化时扫描所有 bean 和包声明。 您需要为您的类文件添加 **@ComponentScan** 注解以扫描您在项目中添加的组件。 观察以下代码以更好地理解 − ``` import org.springframework.boot.SpringApplication; import org.springframework.context.annotation.ComponentScan; @ComponentScan public class DemoApplication { public static void main(String[] args) { SpringApplication.run(DemoApplication.class, args); } } ```