SpringBoot-32-常用注解汇总2

简介: SpringBoot-32-常用注解汇总2在上一章节我们已经讲解了SpringBoot中Controller相关注解,没有看的可以了解一下SpringBoot-31-Controller相关注解详解

SpringBoot-32-常用注解汇总2

在上一章节我们已经讲解了SpringBoot中Controller相关注解,没有看的可以了解一下SpringBoot-31-Controller相关注解详解


请求参数类注解

@PathVariable


表示接收请求路径中占位符的值,通过路径映射取值,参数都用 “/” 按照约定的顺序拼接在方法后面,格式为,格式如下:

@PathVariable("id")
通过@PathVariable,可以将URL中的占位符{id}绑定到处理器类的方法
@GetMapping("/variable/{id}/{name}")
请求路径:http://localhost:8888/request/variable/1/james


实现代码如下

    @GetMapping("/variable/{id}/{name}")
    public String Test(@PathVariable("id")String id,@PathVariable("name")String name){
        return "id: "+id +" name: "+name;
    }



注意如下:

测试结果如下:






fde73e5baa2ee908002a39c69266c027.png

@RequestParam

@RequestParam主要用于将请求参数区域的数据映射到控制层方法的参数上,,使用键值对方式取值,方法名后面加 “?” 开始,多个参数用 “&” 拼接,格式如下

@RequestParam(value = "id",required = false,defaultValue ="1")
请求路径:http://localhost:8888/request/param?name=param


代码实现如下

    @GetMapping("/param")
    public String param(@RequestParam(value = "id",required = false,defaultValue ="1")String id,
                        @RequestParam(value = "name",required = true)String name){
        return "id: "+id +" name: "+name;
    }



注意:**@RequestParam**有四个参数


name:绑定参数的名称


value:和参数name表示的意思一样是name的别名


required:标记参数是否是必须的


defaultValue:如果请求中没有这个参数,那么就使用默认值


测试结果如下:


测试链接:http://localhost:8888/request/param?name=james


f43e6bc54f68d3091107bbeabb59de91.png


@RequestHeader

@RequestHeader把Request请求header部分的值绑定到方法的参数上,也有四个参数和@RequestParam参数含义一样

代码实现如下

    @GetMapping(value="/header")
    public String header(
            @RequestHeader("User-Agent") String userAgent,
            @RequestHeader(value="Accept") String[] accepts){
        return "User-Agent: "+userAgent+"  accept:  "+accepts.toString();
    }



我们使用浏览器测试连接http://localhost:8888/request/header

结果如下:


0747d03870642f5a52b7108928990ab1.png

@CookieValue

@CookieValue绑定Cookie数据值也有四个参数和@RequestParam参数含义一样

代码如下:

    @GetMapping(value="/cookie")
    public String Cookie(
            @CookieValue(value="SESSIONID", defaultValue="") String SESSIONID){
        return "SESSIONID: "+SESSIONID;
    }

测试结果:因为我们Cookie为空,所以返回结果如下:

@Configuration相关注解



@Configuration

@Configuration注解是在Spring 3.0开始添加进去的,用来代替applicationContext.xml配置文件,所以只要是这个配置文件可以实现的事情,都可以通过这个注解在类中进行注册相当于标签。

例子

@Configuration
public class MyConfigTest {
    public MyConfigTest(){
        System.out.println("my config test");
    }
}



启动程序,springboot容器初始化时就自动加载这个类了

@Bean注解


@Bean注解使用在方法上面,相当于之前配置文件.xml中的标签,用于注册bean对象,一般是和**@Configuration**注解配合使用的。

    @Bean
    public String configtest(){
        return "hello config bean";
    }



@Autowired

@Autowired 是根据 类型 (byType)注入的 ,然后在找到type类型的bean时,如果发现有异常(不唯一等),会再去根据name去找bean注入


  • 在Controller中获取并使用我们的configtest的bean,代码如下
@RestController
public class ConfigController {
    @Autowired
    private String configtest;
    @GetMapping("beanconfig")
    public String beanconfig(){
        return configtest;
    }
}



  • 测试结果:

@Qualifier注解


当有多个同一类型的Bean时,可以用@Qualifier(“name”)来指定。与@Autowired配合使用

  • 添加配置类
@Data
public class TestConfigurationProperties {
    private String  epochStr;
    private String timeBits;
    private String workerBits;
    private String seqBits;
}



  • 在MyConfigTest类中注入bean
    @Bean("testconfigurationproperties2")
    public TestConfigurationProperties testConfigurationProperties2(){
        TestConfigurationProperties properties = new TestConfigurationProperties();
        properties.setEpochStr("test2");
        properties.setSeqBits("test2");
        properties.setTimeBits("test2");
        properties.setWorkerBits("test2");
        return properties;
    }
    @Bean("testconfigurationproperties3")
    public TestConfigurationProperties testConfigurationProperties3(){
        TestConfigurationProperties properties = new TestConfigurationProperties();
        properties.setEpochStr("test3");
        properties.setSeqBits("test3");
        properties.setTimeBits("test3");
        properties.setWorkerBits("test3");
        return properties;
    }


  • 在controller中实现
    @Autowired
    @Qualifier("testconfigurationproperties2")
    private TestConfigurationProperties configurationProperties2;
    @Autowired
    @Qualifier("testconfigurationproperties3")
    private TestConfigurationProperties configurationProperties3;
    @GetMapping("/configproperties2")
    public String configproperties2(){
        return configurationProperties2.toString();
    }
    @GetMapping("/configproperties3")
    public String configproperties3(){
        return configurationProperties3.toString();
    }


  • 测试结果

分别访问http://localhost:8888/configproperties2和http://localhost:8888/configproperties2展示测试结果

928046a48ce558abe6e8042ed4277070.png

d2928b52f02eec697f3e46c8d17ccc4d.png


@Resource


@Resource根据Bean的name去获取bean**不像@Autowired **是通过找type类型的bean时,如果没有指定name属性,并且按照默认的名称仍然找不到依赖对象时, @Resource注解会回退到按类型装配。但一旦指定了name属性,就只能按名称装配了



  • controller代码实现如下
    @Resource(name = "testconfigurationproperties3")
    private TestConfigurationProperties configurationProperties4;
    @GetMapping("/configurationProperties4")
    public String configurationProperties4(){
        return configurationProperties4.toString();
    }



  • 测试结果如下


04f86d33a7928d61d4f6468f409ed0ff.png


Properties使用的相关注解


====================


@PropertySource

我们在开发的时候经常使用配置文件,使用@PropertySource注解我们可以注册一个配置文件,一般和@Configuration配合使用。


在src\main\resources文件夹下添加test.properties属性文件


test.epochStr=2019-12-29
test.timeBits=30
test.workerBits=32
test.seqBits=1


  • 注册Properties文件,一般和@Configuration注解配合使用
@Configuration
@PropertySource("classpath:test.properties")
public class Testproperties {
}



注意yaml文件不能用在@PropertySource中。如果你使用@PropertySource,则必须指定properties文件


@Value注解

将test.properties文件中的属性,赋值给普通变量,可以直接在变量声明之上添加@Value()注解:

@Data
@Configuration
@PropertySource("classpath:test.properties")
public class Testproperties {
    @Value("${test.epochStr}")
    private String  epochStr;
    @Value("${test.timeBits}")
    private String timeBits;
    @Value("${test.workerBits}")
    private String workerBits;
    @Value("${test.seqBits}")
    private String seqBits;
}

在Controller中获取并使用我们的Testproperties的bean,代码如下

@RestController
public class PropertyController {
    @Autowired
    private Testproperties testproperties;
    @GetMapping("/properties")
    public String testproperties(){
        return testproperties.toString();
    }
}


  • 测试结果

@ConfigurationProperties


@ConfigurationProperties默认读取的就是application.yml或者application.properties文件和@PropertySource注解很相似

  • application.yml中配置如下
server:
  port: 8888
uid:
  epochStr: 'yml'
  timeBits: 30
  workerBits: 32
  seqBits: 1



  • 使用@ConfigurationProperties注解结合@Configuration将我们的属性封装成Bean
@Data
@Configuration
@ConfigurationProperties(prefix = "uid")
public class UidConfigurationProperties {
    private String  epochStr;
    private String timeBits;
    private String workerBits;
    private String seqBits;
}


  • 在Controller中获取并使用我们的TestConfigurationProperties的bean,代码如下
    @Autowired
    private UidConfigurationProperties uidConfigurationProperties;
    @GetMapping("/uid")
    public String uid(){
        return uidConfigurationProperties.toString();
    }
  • 测试结果

目录
相关文章
|
4月前
|
缓存 监控 Java
SpringBoot @Scheduled 注解详解
使用`@Scheduled`注解实现方法周期性执行,支持固定间隔、延迟或Cron表达式触发,基于Spring Task,适用于日志清理、数据同步等定时任务场景。需启用`@EnableScheduling`,注意线程阻塞与分布式重复问题,推荐结合`@Async`异步处理,提升任务调度效率。
711 128
|
4月前
|
XML 安全 Java
使用 Spring 的 @Aspect 和 @Pointcut 注解简化面向方面的编程 (AOP)
面向方面编程(AOP)通过分离横切关注点,如日志、安全和事务,提升代码模块化与可维护性。Spring 提供了对 AOP 的强大支持,核心注解 `@Aspect` 和 `@Pointcut` 使得定义切面与切入点变得简洁直观。`@Aspect` 标记切面类,集中处理通用逻辑;`@Pointcut` 则通过表达式定义通知的应用位置,提高代码可读性与复用性。二者结合,使开发者能清晰划分业务逻辑与辅助功能,简化维护并提升系统灵活性。Spring AOP 借助代理机制实现运行时织入,与 Spring 容器无缝集成,支持依赖注入与声明式配置,是构建清晰、高内聚应用的理想选择。
523 0
|
4月前
|
Java 测试技术 API
将 Spring 的 @Embedded 和 @Embeddable 注解与 JPA 结合使用的指南
Spring的@Embedded和@Embeddable注解简化了JPA中复杂对象的管理,允许将对象直接嵌入实体,减少冗余表与连接操作,提升数据库设计效率。本文详解其用法、优势及适用场景。
342 126
|
5月前
|
XML JSON Java
Spring框架中常见注解的使用规则与最佳实践
本文介绍了Spring框架中常见注解的使用规则与最佳实践,重点对比了URL参数与表单参数的区别,并详细说明了@RequestParam、@PathVariable、@RequestBody等注解的应用场景。同时通过表格和案例分析,帮助开发者正确选择参数绑定方式,避免常见误区,提升代码的可读性与安全性。
|
3月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
481 2
|
4月前
|
Java 测试技术 数据库
使用Spring的@Retryable注解进行自动重试
在现代软件开发中,容错性和弹性至关重要。Spring框架提供的`@Retryable`注解为处理瞬时故障提供了一种声明式、可配置的重试机制,使开发者能够以简洁的方式增强应用的自我恢复能力。本文深入解析了`@Retryable`的使用方法及其参数配置,并结合`@Recover`实现失败回退策略,帮助构建更健壮、可靠的应用程序。
565 1
使用Spring的@Retryable注解进行自动重试
|
4月前
|
XML Java 数据格式
常用SpringBoot注解汇总与用法说明
这些注解的使用和组合是Spring Boot快速开发和微服务实现的基础,通过它们,可以有效地指导Spring容器进行类发现、自动装配、配置、代理和管理等核心功能。开发者应当根据项目实际需求,运用这些注解来优化代码结构和服务逻辑。
356 12
|
4月前
|
传感器 Java 数据库
探索Spring Boot的@Conditional注解的上下文配置
Spring Boot 的 `@Conditional` 注解可根据不同条件动态控制 Bean 的加载,提升应用的灵活性与可配置性。本文深入解析其用法与优势,并结合实例展示如何通过自定义条件类实现环境适配的智能配置。
226 0
探索Spring Boot的@Conditional注解的上下文配置
|
4月前
|
智能设计 Java 测试技术
Spring中最大化@Lazy注解,实现资源高效利用
本文深入探讨了 Spring 框架中的 `@Lazy` 注解,介绍了其在资源管理和性能优化中的作用。通过延迟初始化 Bean,`@Lazy` 可显著提升应用启动速度,合理利用系统资源,并增强对 Bean 生命周期的控制。文章还分析了 `@Lazy` 的工作机制、使用场景、最佳实践以及常见陷阱与解决方案,帮助开发者更高效地构建可扩展、高性能的 Spring 应用程序。
188 0
Spring中最大化@Lazy注解,实现资源高效利用