乐趣区

关于java:肝了一周总结的SpringBoot常用注解大全一目了然

平时应用 SpringBoot 开发我的项目,少不了要应用到它的注解。这些注解让咱们解脱了繁琐的传统 Spring XML 配置,让咱们开发我的项目更加高效,明天咱们就来聊聊 SpringBoot 中罕用的注解!

SpringBoot 实战电商我的项目 mall(50k+star)地址:https://github.com/macrozheng/mall

罕用注解概览

这里整顿了一张 SpringBoot 罕用注解的思维导图,本文次要解说这些注解的用法。

组件相干注解

@Controller

用于润饰 MVC 中 controller 层的组件,SpringBoot 中的组件扫描性能会辨认到该注解,并为润饰的类实例化对象,通常与 @RequestMapping 联用,当 SpringMVC 获取到申请时会转发到指定门路的办法进行解决。

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {}

@Service

用于润饰 service 层的组件,service层组件专一于零碎业务逻辑的解决,同样会被组件扫描并生成实例化对象。

/**
 * @auther macrozheng
 * @description 后盾用户治理 Service 实现类
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Service
public class UmsAdminServiceImpl implements UmsAdminService {}

@Repository

用于润饰 dao 层的组件,dao层组件专一于零碎数据的解决,例如数据库中的数据,同样会被组件扫描并生成实例化对象。

/**
 * @auther macrozheng
 * @description 后盾用户与角色关系治理自定义 Dao
 * @date 2018/10/8
 * @github https://github.com/macrozheng
 */
@Repository
public interface UmsAdminRoleRelationDao {}

@Component

用于润饰 SpringBoot 中的组件,会被组件扫描并生成实例化对象。@Controller@Service@Repository都是非凡的组件注解。

/**
 * @auther macrozheng
 * @description 勾销订单音讯的生产者组件
 * @date 2018/9/14
 * @github https://github.com/macrozheng
 */
@Component
public class CancelOrderSender {}

依赖注入注解

@Autowired

会依据对象的 类型 主动注入依赖对象,默认要求注入对象实例必须存在,能够配置 required=false 来注入不肯定存在的对象。

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    private UmsAdminService adminService;
}

@Resource

默认会依据对象的 名称 主动注入依赖对象,如果想要依据类型进行注入,能够设置属性为type = UmsAdminService.class

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    @Resource(name = "umsAdminServiceImpl")
    private UmsAdminService adminService;
}

@Qualifier

当同一个对象有多个实例能够注入时,应用 @Autowired 注解无奈进行注入,这时能够应用 @Qualifier 注解指定实例的名称进行准确注入。

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    @Qualifier("umsAdminServiceImpl")
    private UmsAdminService adminService;
}

实例与生命周期相干注解

@Bean

用于润饰办法,标识该办法会创立一个 Bean 实例,并交给 Spring 容器来治理。

/**
 * @auther macrozheng
 * @description RestTemplate 相干配置
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Configuration
public class RestTemplateConfig {
    @Bean
    public RestTemplate restTemplate(){return new RestTemplate();
    }
}

@Scope

用于申明一个 SpringBean实例的作用域,作用域的范畴有以下几种:

  • singleton:单例模式,在 Spring 容器中该实例惟一,Spring 默认的实例模式。
  • prototype:原型模式,每次应用实例都将从新创立。
  • request:在同一申请中应用雷同的实例,不同申请从新创立。
  • session:在同一会话中应用雷同的实例,不同会话从新创立。
/**
 * @auther macrozheng
 * @description RestTemplate 相干配置
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Configuration
public class RestTemplateConfig {
    @Bean
    @Scope("singleton")
    public RestTemplate restTemplate(){return new RestTemplate();
    }
}

@Primary

当同一个对象有多个实例时,优先选择该实例。

/**
 * @auther macrozheng
 * @description Jackson 相干配置,配置 json 不返回 null 的字段
 * @date 2018/8/2
 * @github https://github.com/macrozheng
 */
@Configuration
public class JacksonConfig {
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        return objectMapper;
    }
}

@PostConstruct

用于润饰办法,当对象实例被创立并且依赖注入实现后执行,可用于对象实例的初始化操作。

@PreDestroy

用于润饰办法,当对象实例将被 Spring 容器移除时执行,可用于对象实例持有资源的开释。

@PostConstruct、@PreDestroy 示例

/**
 * @auther macrozheng
 * @description 动静权限数据源,用于获取动静权限规定
 * @date 2020/2/7
 * @github https://github.com/macrozheng
 */
public class DynamicSecurityMetadataSource implements FilterInvocationSecurityMetadataSource {

    private static Map<String, ConfigAttribute> configAttributeMap = null;
    @Autowired
    private DynamicSecurityService dynamicSecurityService;

    @PostConstruct
    public void loadDataSource() {configAttributeMap = dynamicSecurityService.loadDataSource();
    }

    @PostConstruct
    public void loadDataSource() {configAttributeMap = dynamicSecurityService.loadDataSource();
    }

    @PreDestroy
    public void clearDataSource() {configAttributeMap.clear();
        configAttributeMap = null;
    }
}

SpringMVC 相干注解

@RequestMapping

可用于将 Web 申请门路映射到解决类的办法上,当作用于类上时,能够对立类中所有办法的路由门路,当作用于办法上时,可独自指定办法的路由门路。

method属性能够指定申请的形式,如 GET、POST、PUT、DELETE 等。

@RequestBody

示意办法的申请参数为 JSON 格局,从 Body 中传入,将主动绑定到办法参数对象中。

@ResponseBody

示意办法将返回 JSON 格局的数据,会主动将返回的对象转化为 JSON 数据。

@RequestParam

用于接管申请参数,能够是如下三种模式:

  • query param:GET 申请拼接在地址里的参数。
  • form data:POST 表单提交的参数。
  • multipart:文件上传申请的局部参数。

@PathVariable

用于接管申请门路中的参数,罕用于 REST 格调的 API。

@RequestPart

用于接管文件上传中的文件参数,通常是 multipart/form-data 模式传入的参数。

/**
 * @auther macrozheng
 * @description MinIO 对象存储管理 Controller
 * @date 2019/12/25
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/minio")
public class MinioController {@RequestMapping(value = "/upload", method = RequestMethod.POST)
    @ResponseBody
    public CommonResult upload(@RequestPart("file") MultipartFile file) {
            // 省略文件上传操作...
            return CommonResult.success(minioUploadDto);
    }
}

SpringMVC 注解示例

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {@RequestMapping(value = "/register", method = RequestMethod.POST)
    @ResponseBody
    public CommonResult<UmsAdmin> register(@RequestBody UmsAdminParam umsAdminParam) {UmsAdmin umsAdmin = adminService.register(umsAdminParam);
        if (umsAdmin == null) {return CommonResult.failed();
        }
        return CommonResult.success(umsAdmin);
    }
    
    @RequestMapping(value = "/list", method = RequestMethod.GET)
    @ResponseBody
    public CommonResult<CommonPage<UmsAdmin>> list(@RequestParam(value = "keyword", required = false) String keyword,
                                                   @RequestParam(value = "pageSize", defaultValue = "5") Integer pageSize,
                                                   @RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum) {List<UmsAdmin> adminList = adminService.list(keyword, pageSize, pageNum);
        return CommonResult.success(CommonPage.restPage(adminList));
    }

    @RequestMapping(value = "/{id}", method = RequestMethod.GET)
    @ResponseBody
    public CommonResult<UmsAdmin> getItem(@PathVariable Long id) {UmsAdmin admin = adminService.getItem(id);
        return CommonResult.success(admin);
    }
}

@RestController

用于示意 controller 层的组件,与 @Controller 注解的不同在于,相当于在每个申请解决办法上都增加了 @ResponseBody 注解,这些办法都将返回 JSON 格局数据。

@GetMapping

用于示意 GET 申请办法,等价于@RequestMapping(method = RequestMethod.GET)

@PostMapping

用于示意 POST 申请办法,等价于@RequestMapping(method = RequestMethod.POST)

REST 格调注解示例

/**
 * @auther macrozheng
 * @description 后盾用户治理 Controller
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@RestController
@RequestMapping("/admin")
public class UmsAdminController {@PostMapping("/register")
    public CommonResult<UmsAdmin> register(@RequestBody UmsAdminParam umsAdminParam) {UmsAdmin umsAdmin = adminService.register(umsAdminParam);
        if (umsAdmin == null) {return CommonResult.failed();
        }
        return CommonResult.success(umsAdmin);
    }

    @GetMapping("/list")
    public CommonResult<CommonPage<UmsAdmin>> list(@RequestParam(value = "keyword", required = false) String keyword,
                                                   @RequestParam(value = "pageSize", defaultValue = "5") Integer pageSize,
                                                   @RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum) {List<UmsAdmin> adminList = adminService.list(keyword, pageSize, pageNum);
        return CommonResult.success(CommonPage.restPage(adminList));
    }
}

配置相干注解

@Configuration

用于申明一个 Java 模式的配置类,SpringBoot 举荐应用 Java 配置,在该类中申明的 Bean 等配置将被 SpringBoot 的组件扫描性能扫描到。

/**
 * @auther macrozheng
 * @description MyBatis 相干配置
 * @date 2019/4/8
 * @github https://github.com/macrozheng
 */
@Configuration
@MapperScan({"com.macro.mall.mapper","com.macro.mall.dao"})
public class MyBatisConfig {}

@EnableAutoConfiguration

启用 SpringBoot 的自动化配置,会依据你在 pom.xml 增加的依赖和 application-dev.yml 中的配置主动创立你须要的配置。

@Configuration
@EnableAutoConfiguration
public class AppConfig {}

@ComponentScan

启用 SpringBoot 的组件扫描性能,将主动拆卸和注入指定包下的 Bean 实例。

@Configuration
@ComponentScan({"xyz.erupt","com.macro.mall.tiny"})
public class EruptConfig {}

@SpringBootApplication

用于示意 SpringBoot 利用中的启动类,相当于 @EnableAutoConfiguration@EnableAutoConfiguration@ComponentScan三个注解的结合体。

@SpringBootApplication
public class MallTinyApplication {public static void main(String[] args) {SpringApplication.run(MallTinyApplication.class, args);
    }

}

@EnableCaching

当增加 Spring Data Redis 依赖之后,可用该注解开启 Spring 基于注解的缓存治理性能。

/**
 * @auther macrozheng
 * @description Redis 配置类
 * @date 2020/3/2
 * @github https://github.com/macrozheng
 */
@EnableCaching
@Configuration
public class RedisConfig extends BaseRedisConfig {}

@value

用于注入在配置文件中配置好的属性,例如咱们能够在 application.yml 配置如下属性:

jwt:
  tokenHeader: Authorization #JWT 存储的申请头
  secret: mall-admin-secret #JWT 加解密应用的密钥
  expiration: 604800 #JWT 的超期限工夫(60*60*24*7)
  tokenHead: 'Bearer'  #JWT 负载中拿到结尾

而后在 Java 类中就能够应用 @Value 注入并进行应用了。

public class JwtTokenUtil {@Value("${jwt.secret}")
    private String secret;
    @Value("${jwt.expiration}")
    private Long expiration;
    @Value("${jwt.tokenHead}")
    private String tokenHead;
}

@ConfigurationProperties

用于批量注入内部配置,以对象的模式来导入指定前缀的配置,比方这里咱们在 application.yml 中指定了 secure.ignored 为前缀的属性:

secure:
  ignored:
    urls: #平安门路白名单
      - /swagger-ui/
      - /swagger-resources/**
      - /**/v2/api-docs
      - /**/*.html
      - /**/*.js
      - /**/*.css
      - /**/*.png
      - /**/*.map
      - /favicon.ico
      - /actuator/**
      - /druid/**

而后在 Java 类中定义一个 urls 属性就能够导入配置文件中的属性了。

/**
 * @auther macrozheng
 * @description SpringSecurity 白名单资源门路配置
 * @date 2018/11/5
 * @github https://github.com/macrozheng
 */
@Getter
@Setter
@Configuration
@ConfigurationProperties(prefix = "secure.ignored")
public class IgnoreUrlsConfig {private List<String> urls = new ArrayList<>();

}

@Conditional

用于示意当某个条件满足时,该组件或 Bean 将被 Spring 容器创立,上面是几个罕用的条件注解。

  • @ConditionalOnBean:当某个 Bean 存在时,配置失效。
  • @ConditionalOnMissingBean:当某个 Bean 不存在时,配置失效。
  • @ConditionalOnClass:当某个类在 Classpath 存在时,配置失效。
  • @ConditionalOnMissingClass:当某个类在 Classpath 不存在时,配置失效。
/**
 * @auther macrozheng
 * @description Jackson 相干配置,配置 json 不返回 null 的字段
 * @date 2018/8/2
 * @github https://github.com/macrozheng
 */
@Configuration
public class JacksonConfig {
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        return objectMapper;
    }
}

数据库事务相干注解

@EnableTransactionManagement

启用 Spring 基于注解的事务管理性能,须要和 @Configuration 注解一起应用。

/**
 * @auther macrozheng
 * @description MyBatis 相干配置
 * @date 2019/4/8
 * @github https://github.com/macrozheng
 */
@Configuration
@EnableTransactionManagement
@MapperScan({"com.macro.mall.mapper","com.macro.mall.dao"})
public class MyBatisConfig {}

@Transactional

示意办法和类须要开启事务,当作用与类上时,类中所有办法均会开启事务,当作用于办法上时,办法开启事务,办法上的注解无奈被子类所继承。

/**
 * @auther macrozheng
 * @description 前台订单治理 Service
 * @date 2018/8/30
 * @github https://github.com/macrozheng
 */
public interface OmsPortalOrderService {

    /**
     * 依据提交信息生成订单
     */
    @Transactional
    Map<String, Object> generateOrder(OrderParam orderParam);
}

SpringSecurity 相干注解

@EnableWebSecurity

启用 SpringSecurity 的 Web 性能。

@EnableGlobalMethodSecurity

启用 SpringSecurity 基于办法的平安性能,当咱们应用 @PreAuthorize 润饰接口办法时,须要有对应权限的用户能力拜访。

SpringSecurity 配置示例

/**
 * @auther macrozheng
 * @description SpringSecurity 配置
 * @date 2019/10/8
 * @github https://github.com/macrozheng
 */
@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfig{}

全局异样解决注解

@ControllerAdvice

常与 @ExceptionHandler 注解一起应用,用于捕捉全局异样,能作用于所有 controller 中。

@ExceptionHandler

润饰办法时,示意该办法为解决全局异样的办法。

全局异样解决示例

/**
 * @auther macrozheng
 * @description 全局异样解决
 * @date 2020/2/27
 * @github https://github.com/macrozheng
 */
@ControllerAdvice
public class GlobalExceptionHandler {

    @ResponseBody
    @ExceptionHandler(value = ApiException.class)
    public CommonResult handle(ApiException e) {if (e.getErrorCode() != null) {return CommonResult.failed(e.getErrorCode());
        }
        return CommonResult.failed(e.getMessage());
    }
}

AOP 相干注解

@Aspect

用于定义切面,切面是告诉和切点的联合,定义了何时、何地利用告诉性能。

@Before

示意前置告诉(Before),告诉办法会在指标办法调用之前执行,告诉形容了切面要实现的工作以及何时执行。

@After

示意后置告诉(After),告诉办法会在指标办法返回或抛出异样后执行。

@AfterReturning

示意返回告诉(AfterReturning),告诉办法会在指标办法返回后执行。

@AfterThrowing

示意异样告诉(AfterThrowing),告诉办法会在指标办法返回后执行。

@Around

示意盘绕告诉(Around),告诉办法会将指标办法封装起来,在指标办法调用之前和之后执行自定义的行为。

@Pointcut

定义切点表达式,定义了告诉性能被利用的范畴。

@Order

用于定义组件的执行程序,在 AOP 中指的是切面的执行程序,value 属性越低优先级越高。

AOP 相干示例

/**
 * @auther macrozheng
 * @description 对立日志解决切面
 * @date 2018/4/26
 * @github https://github.com/macrozheng
 */
@Aspect
@Component
@Order(1)
public class WebLogAspect {private static final Logger LOGGER = LoggerFactory.getLogger(WebLogAspect.class);

    @Pointcut("execution(public * com.macro.mall.tiny.controller.*.*(..))")
    public void webLog() {}

    @Before("webLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable { }

    @AfterReturning(value = "webLog()", returning = "ret")
    public void doAfterReturning(Object ret) throws Throwable { }

    @Around("webLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable {WebLog webLog = new WebLog();
        // 省略日志解决操作...
        Object result = joinPoint.proceed();
        LOGGER.info("{}", JSONUtil.parse(webLog));
        return result;
    }
    
}

测试相干注解

@SpringBootTest

用于指定测试类启用 Spring Boot Test 性能,默认会提供 Mock 环境。

@Test

指定办法为测试方法。

测试示例

/**
 * @auther macrozheng
 * @description JUnit 根本测试
 * @date 2022/10/11
 * @github https://github.com/macrozheng
 */
@SpringBootTest
public class FirstTest {
    @Test
    public void test() {
        int a=1;
        Assertions.assertEquals(1,a);
    }
}

总结

这些 SpringBoot 注解根本都是我平时做我的项目罕用的注解,在我的电商实战我的项目 mall 中根本都用到了,这里做了一番整顿演绎,心愿对大家有所帮忙!

退出移动版