Spring注解

简介: Spring注解相关介绍

装配Bean:

1.自动扫描:

@ComponentScan+@Component

@ComponentScan标明采用何种策略去扫描装配Bean

@Component标明哪个类被扫描进入IOC容器

2.自定义第三方Bean:

@Bean+@Configuration/@Component

initMethod() destroyMethod()

FULL模式和LITE模式

FULL:标注有@Configuration注解的类被称为full模式的配置类。

LITE:当@Bean方法在没有使用@Configuration注释的类中声明时,他们被称为在Lite模式下处理。

FULL模式下,配置类会被CGLIB增强(生成代理对象),放进IOC容器内的是代理;该模式下,配置类内部可以通过方法调用来处理依赖,并且能够保证是同一个实例,都指向IOC内的那个单例。

该模式下@bean方法不能被private/final修饰。

LITE模式下,配置类不会被增强,放进IOC容器内的就是本尊,配置类内部不能通过方法调用来处理依赖,否则内次都生成的事一个新的实例而并非IOC容器内的单例。

该模式下配置类就是一普通类,所以@Bean方法可以使用private/final进行修饰。

FULL模式:
@Configuration
public class ClassA {
    @Bean
    public String A(){
        System.out.println("createA");
        return "";
    }
    @Bean
    public String B(){
        A();
        System.out.println("createB");
        return "";
    }
}

结果:createA createB

LITE模式:
@Component
public class ClassA {
    @Bean
    public String A(){
        System.out.println("createA");
        return "";
    }
    @Bean
    public String B(){
        A();
        System.out.println("createB");
        return "";
    }
}

结果:createA createA createB

Bean作用域

作用域 描述
singleton 默认值,IOC容器只存在单例
prototype 每当从IOC容器中取出一个Bean,则创建一个新的Bean
request 每次HTTP请求都会创建一个新的Bean,该作用域仅适用于web的Spring WebApplicationContext环境
session 同一个HTTP Session共享一个Bean,不同Session使用不同的Bean。该作用域仅适用于web的Spring WebApplicationContext环境
application 限定一个Bean的作用域为ServletContext的生命周期。该作用域仅适用于web的Spring WebApplicationContext环境。

Bean注入消除歧义:

当一个借口有2个不同的实现时,使用@Autowired会报错,此时使用@Primary注解,此注解表示这个bean优先于其他bean。

或者用@Qualifier指定注入Bean的名称

注入配置文件的值

@Value

@ConfigurationProperties

@PropertySource加载指定的配置文件,如@PropertySource("classpath:jdbc.properties")

区别:

区别 @Configuration @Value
功能 批量注入配置文件中的属性 一个个指定
松散绑定 支持 不支持
SpEL 不支持 支持
JSR303数据校验 支持 不支持
复杂类型封装 支持 不支持

Spring EL

${...}代表占位符

#{...}启用spring表达式,具有运算功能

/*
   * @Value注解等同于XML配置中的<property/>标签, 
   * SpringEL同样支持在XML<property/>中编写
  */
  // 注入简单值,输出num为5
  @Value("#{5}")
  private Integer num;
  // 注入ID为testConstant的Bean
  @Value("#{testConstant}")
  private TestConstant Constant;
  // 注入ID为testConstant Bean中的STR常量/变量
  @Value("#{testConstant.STR}")
  private String str;

SpEL调用方法:

/*
   * TestConstant类中有两个方法重载,
   * 返回值为String类型
  */
  // 调用无参方法
  @Value("#{testConstant.showProperty}")
  private String method1;
  // 有参接收字符串的方法
  @Value("#{testConstant.showProperty('Hello')}")
  private String method2;
  /*
   * 若然希望方法返回的String为大写
  */
  @Value("#{testConstant.showProperty().toUpperCase()}")
  private String method3;
  /*
   * 若使用method3这种方式,若然showProperty返回为null, 
   * 将会抛出NullPointerException,可以使用以下方式避免
  */
  @Value("#{testConstant.showProperty()?.toUpperCase}")
  private String method4;

SpringEL进行运算及逻辑操作:

// 拼接字符串
  @Value("#{testConstant.nickname + ' ' + testConstant.name}")
  private String concatString;
  // 对数字类型进行运算,testConstant拥有num属性
  @Value("#{ 3 * T(java.lang.Math).PI + testConstant.num}")
  private double operation;
  // 进行逻辑运算
  @Value("#{testConstant.num > 100 and testConstant.num <= 200}")
  private boolean logicOperation;
  // 进行或非逻辑操作
  @Value("#{ not testConstant.num == 100 or testConstant.num <= 200}")
  private boolean logicOperation2;
  // 使用三元运算符
  @Value("#{testConstant.num > 100 ? testConstant.num : testConstant.num + 100}")
  private Integer logicOperation3;
}

Web相关注解

一个请求方法只可以有一个@RequestBody,但是可以有多个@RequestParam和@PathVariable

@RequestParam - 获取查询参数

@PathVariable - 获取路径参数

如下:

请求:/test/1/ss?name=abc

即 id=1 name=abc

@GetMapping("/test/{id}/ss")
    public String ss(@PathVariable("id") Long id, @RequestParam(value = "name", required = false) String name){
        System.out.println("ss");
        return "ss";
    }
相关文章
|
3月前
|
XML Java 数据格式
SpringBoot入门(8) - 开发中还有哪些常用注解
SpringBoot入门(8) - 开发中还有哪些常用注解
65 0
|
2天前
|
缓存 Java 数据库
SpringBoot缓存注解使用
Spring Boot 提供了一套方便的缓存注解,用于简化缓存管理。通过 `@Cacheable`、`@CachePut`、`@CacheEvict` 和 `@Caching` 等注解,开发者可以轻松地实现方法级别的缓存操作,从而提升应用的性能和响应速度。合理使用这些注解可以大大减少数据库的访问频率,优化系统性能。
122 85
|
4月前
|
Java Spring
在使用Spring的`@Value`注解注入属性值时,有一些特殊字符需要注意
【10月更文挑战第9天】在使用Spring的`@Value`注解注入属性值时,需注意一些特殊字符的正确处理方法,包括空格、引号、反斜杠、新行、制表符、逗号、大括号、$、百分号及其他特殊字符。通过适当包裹或转义,确保这些字符能被正确解析和注入。
257 3
|
2月前
|
Java Spring
【Spring】方法注解@Bean,配置类扫描路径
@Bean方法注解,如何在同一个类下面定义多个Bean对象,配置扫描路径
175 73
|
2月前
|
Java Spring 容器
【SpringFramework】Spring IoC-基于注解的实现
本文主要记录基于Spring注解实现IoC容器和DI相关知识。
54 21
|
2月前
|
存储 Java Spring
【Spring】获取Bean对象需要哪些注解
@Conntroller,@Service,@Repository,@Component,@Configuration,关于Bean对象的五个常用注解
|
2月前
|
Java Spring
【Spring配置】idea编码格式导致注解汉字无法保存
问题一:对于同一个项目,我们在使用idea的过程中,使用汉字注解完后,再打开该项目,汉字变成乱码问题二:本来a项目中,汉字注解调试好了,没有乱码了,但是创建出来的新的项目,写的注解又成乱码了。
|
3月前
|
XML JSON Java
SpringBoot必须掌握的常用注解!
SpringBoot必须掌握的常用注解!
139 4
SpringBoot必须掌握的常用注解!
|
3月前
|
前端开发 Java Spring
Spring MVC核心:深入理解@RequestMapping注解
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的核心,它将HTTP请求映射到控制器的处理方法上。本文将深入探讨`@RequestMapping`注解的各个方面,包括其注解的使用方法、如何与Spring MVC的其他组件协同工作,以及在实际开发中的应用案例。
59 4
|
3月前
|
前端开发 Java 开发者
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
201 2