Spring Boot 由于没有XML文件,所以所有的Bean管理都放入在一个配置类中实现。 配置类就是类上具有@Configuration的类。这个类就相当于之前的applicationContext.xml。
1.配置初始设置
1.pom.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.test</groupId>
<artifactId>SpringBootBeanAnnoTest</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- 2.引入当前项目的父项目,会继承父项目配置,自动引入父项目中所需的所有配置项和依赖包 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.4.5</version>
</parent>
<!-- 3.本项目依赖的其他包 -->
<dependencies>
<!-- 引入SpringBoot核心启动包,内部也会自动引入它所依赖的第三方包 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<version>2.4.5</version>
</dependency>
<!-- 引入SpringBoot-web,它是SpringMVC项目的启动器(Starter),内置了内嵌式的Tomcat -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.4.5</version>
</dependency>
<!-- 引入SpringBoot对测试的支持starter -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>2.4.5</version>
<scope>test</scope>
</dependency>
<!-- 引入jUnit单元测试依赖包 -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13.1</version>
</dependency>
<!-- 引入FastJson依赖包 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.79</version>
</dependency>
<!-- 引入Lombok依赖包 -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.20</version>
</dependency>
</dependencies>
<!-- 4.当前项目统一需要的打包、编译插件 -->
<build>
<plugins>
<!-- 引入maven编译插件,maven默认会使用JDK1.5编译打包,我们指定为1.8 -->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<!-- 引入SpringBoot项目打包工具 -->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.4.5</version>
<configuration>
<!-- 如果没有该配置,devTools不会起
作用,应用不会自动restart重启 --> <fork>true</fork> <includeSystemScope>true</includeSystemScope> </configuration> </plugin> </plugins> </build> </project>
2.resource中application.yml文件
spring: application: name: spring-boot-bean-anno-test server: port: 8088 #设置日志输出的各个选项 logging: level: com.chinasofti.xian.controller: debug
3.运行主体类
package com.test;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
public class SpringBootAppClass {
public static void main(String[] args) {
SpringApplication.run(SpringBootAppClass.class, args);
}
}
2.通过模拟上传设置,理解@Bean的使用
1.新建配置包config,在包中设置配置信息
注意: 配置类要有@Configuration ;方法要有@Bean
2.在appication.yml中设置配置信息
#下面是模拟用于上传使用的自定义配置信息 my-upload-config: black-list: exe,bat,com max-size: 10485760 upload-folder: D:/uploadFiles/
3.config包中设置配置类
1.对应application.yml中的配置,在类中获取application.yml中的部分上传配置对象
package com.test.config;
import lombok.Data;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.context.annotation.Configuration;
@Data
@Configuration
@ConfigurationProperties(prefix = "my-upload-config")
public class UploadConfigLoader {
private String blackList;//上传文件黑名单
private Integer maxSize;//上传文件大小
private String uploadFolder;//上传文件路径
}
2.设置模拟上传助手类 ,模拟部分参数从application.yml中获取,部分从数据库中获取
package com.test.config;
import lombok.Data;
//上传助手类组件,模拟通过它进行文件上传
//@Component//我们对于创建过程较为复杂的组件对象,可以不使用@Component注解完成创建
//我们本例通过@Bean注解,在方法中完成创建和初始化
@Data
public class SmartUploadHelper {
private String whiteNameList;//白名单
private String blackNameList;//黑名单
private int singleFileSize;//单个文件大小限制
private int totalFileSize;//总文件大小显示
private String uploadPath;//上传路径
private String downloadPath;//下载路径
}
4.在运行主体类SpringBootAppClass中加入配置信息
装配方式比较复杂时,使用@Bean,本例中@Bean对象中一部分配置信息来自application.yml,另一部分来自数据库。
package com.test;
import com.test.config.SmartUploadHelper;
import com.test.config.UploadConfigLoader;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.jdbc.DataSourceAutoConfiguration;
import org.springframework.context.annotation.Bean;
@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)
public class SpringBootAppClass {
public static void main(String[] args) {
SpringApplication.run(SpringBootAppClass.class, args);
}
//@Bean的使用:为了通过方法创建一个Bean组件(放入Spring上下文中)
//1).在SpringBoot中,任意能够被扫描到的组件类中,可以随意编写方法在之前使用@Bean注解。
//2).@Bean方法的返回值,就是创建的Bean对象,会自动放入Spring上下文中。
//3).添加了@Bean的方法,会在SpringBoot启动时,自动调用。
//4).@Bean方法的参数,必须是另一个Bean组件对象(例子中为UploadConfigLoader),会自动注入!
//下面的方法会自动调用,我们在其中创建了一个“上传助手类组件Bean对象”,会作为Bean自动放入Spring上下文中
@Bean
public SmartUploadHelper createSmartUploadHelper(UploadConfigLoader uploadConfigLoader){
//创建对象
SmartUploadHelper smartUploadHelper = new SmartUploadHelper();
//下面初始化这个组件对象的6个属性:
//1).其中3个属性,是来自于application.yml中的配置信息
smartUploadHelper.setBlackNameList(uploadConfigLoader.getBlackList());
smartUploadHelper.setTotalFileSize(uploadConfigLoader.getMaxSize());
smartUploadHelper.setUploadPath(uploadConfigLoader.getUploadFolder());
//2).另外的3个属性,模拟从数据库加载的信息,完成初始化
smartUploadHelper.setWhiteNameList("jpg,png,gif");
smartUploadHelper.setSingleFileSize(1048576);
smartUploadHelper.setDownloadPath("D:/downloadFiles/");
//返回值就是创建好的Bean对象,会自动放入Spring上下文中
return smartUploadHelper;
}
}
3.设置controller包,进行测试
建立testController类进行设置
package com.test.controller;
import com.test.config.SmartUploadHelper;
import com.alibaba.fastjson.JSONObject;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.annotation.Resource;
@RestController
@RequestMapping("/")
public class TestController {
@Resource
private SmartUploadHelper smartUploadHelper;
@RequestMapping(value = "testUpload", produces = "application/json;charset=utf-8")
public String testUpload(){
//返回上传助手类中的属性数据,转换为JSON字符串
return JSONObject.toJSONString(smartUploadHelper);
}
}