• Spring/SpringBoot注解用法解析/案例


    Spring注解@Bean、@Component、@Controller、@Service、@Repository…

    它们是Spring的基本标签,在Spring Boot中并未改变它们原来的功能

    1.声明bean的注解

    @Component 组件,通用的注解方式

    @Service 在业务逻辑层使用(service层

    @Repository 在数据访问层使用(dao层

    @Controller 在表现层使用,控制器的声明(C)

    2.注入bean的注解

    @Autowired:由Spring提供

    @Inject:由JSR-330提供

    @Resource:由JSR-250提供

    都可以注解在set方法和属性上,推荐注解在属性上(一目了然,少写代码)。

    3.java配置类相关注解

    @Configuration 声明当前类为配置类,相当于xml形式的Spring配置(类上)

    @Bean 注解在方法上,声明当前方法的返回值为一个bean,替代xml中的方式(方法上)

    @Configuration 声明当前类为配置类,其中内部组合了@Component注解,表明这个类是一个bean(类上)

    @ComponentScan 用于对Component进行扫描,相当于xml中的(类上)

    @WishlyConfiguration 为@Configuration与@ComponentScan的组合注解,可以替代这两个注解

    4.切面(AOP)相关注解

    Spring支持AspectJ的注解式切面编程。

    @Aspect 声明一个切面(类上)

    使用@After、@Before、@Around定义建言(advice),可直接将拦截规则(切点)作为参数。

    @After 在方法执行之后执行(方法上) @Before 在方法执行之前执行(方法上) @Around 在方法执行之前与之后执行(方法上)

    @PointCut 声明切点

    在java配置类中使用@EnableAspectJAutoProxy注解开启Spring对AspectJ代理的支持(类上)

    5.@Bean的属性支持

    @Scope 设置Spring容器如何新建Bean实例(方法上,得有@Bean)

    其设置类型包括:

    • Singleton (单例,一个Spring容器中只有一个bean实例,默认模式),

    • Protetype (每次调用新建一个bean),

    • Request (web项目中,给每个http request新建一个bean),

    • Session (web项目中,给每个http session新建一个bean),

    • GlobalSession(给每一个 global http session新建一个Bean实例)

    @StepScope 在Spring Batch中还有涉及

    @PostConstruct 由JSR-250提供,在构造函数执行完之后执行,等价于xml配置文件中bean的initMethod

    @PreDestory 由JSR-250提供,在Bean销毁之前执行,等价于xml配置文件中bean的destroyMethod

    @Conditional是Spring4新提供的注解,它的作用是按照一定的条件进行判断,满足条件给容器注册bean。

    @Configuration

    用法

    /**
     * 1、配置类里面使用@Bean标注在方法上给容器注册组件,默认也是单实例的
     * 2、配置类本身也是组件
     * 3、proxyBeanMethods:代理bean的方法
     *      Full(proxyBeanMethods = true)(保证每个@Bean方法被调用多少次返回的组件都是单实例的)(默认)
     *      Lite(proxyBeanMethods = false)(每个@Bean方法被调用多少次返回的组件都是新创建的)
     */
    @Configuration(proxyBeanMethods = false) //告诉SpringBoot这是一个配置类 == 配置文件
    public class MyConfig {
    
        /**
         * Full:外部无论对配置类中的这个组件注册方法调用多少次获取的都是之前注册容器中的单实例对象
         * @return
         */
        @Bean //给容器中添加组件。以方法名作为组件的id。返回类型就是组件类型。返回的值,就是组件在容器中的实例
        public User user01(){
            User zhangsan = new User("zhangsan", 18);
            //user组件依赖了Pet组件
            zhangsan.setPet(tomcatPet());
            return zhangsan;
        }
    
        @Bean("tom")
        public Pet tomcatPet(){
            return new Pet("tomcat");
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28

    测试

    @SpringBootConfiguration
    @EnableAutoConfiguration
    @ComponentScan("com.atguigu.boot")
    public class MainApplication {
    
        public static void main(String[] args) {
        //1、返回我们IOC容器
            ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args);
    
        //2、查看容器里面的组件
            String[] names = run.getBeanDefinitionNames();
            for (String name : names) {
                System.out.println(name);
            }
    
        //3、从容器中获取组件
            Pet tom01 = run.getBean("tom", Pet.class);
            Pet tom02 = run.getBean("tom", Pet.class);
            System.out.println("组件:"+(tom01 == tom02));
    
        //4、com.atguigu.boot.config.MyConfig$$EnhancerBySpringCGLIB$$51f1e1ca@1654a892
            MyConfig bean = run.getBean(MyConfig.class);
            System.out.println(bean);
    
        //如果@Configuration(proxyBeanMethods = true)代理对象调用方法。SpringBoot总会检查这个组件是否在容器中有。
            //保持组件单实例
            User user = bean.user01();
            User user1 = bean.user01();
            System.out.println(user == user1);
    
            User user01 = run.getBean("user01", User.class);
            Pet tom = run.getBean("tom", Pet.class);
    
            System.out.println("用户的宠物:"+(user01.getPet() == tom));
        }
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37

    @Import

    将指定类型的组件导入容易,可以是自定义类或者引入的包中的类型,例如导入这2个组件:

    @Import({User.class, DBHelper.class})给容器中自动创建出这两个类型的组件、默认组件的名字就是全类名

    用法

    @Import({User.class, DBHelper.class})
    @Configuration(proxyBeanMethods = false) //告诉SpringBoot这是一个配置类 == 配置文件
    public class MyConfig {
    }
    
    • 1
    • 2
    • 3
    • 4

    测试

    //1、返回我们IOC容器
    ConfigurableApplicationContext run = SpringApplication.run(MainApplication.class, args);
     
    //...
    
    //5、获取组件
    String[] beanNamesForType = run.getBeanNamesForType(User.class);
    
    for (String s : beanNamesForType) {
        System.out.println(s);
    }
    
    DBHelper bean1 = run.getBean(DBHelper.class);
    System.out.println(bean1);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    @Conditional

    条件装配:满足Conditional指定的条件,则进行组件注入

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3b0jCG9L-1662630167158)(/Users/cat/Library/Application Support/typora-user-images/image-20220908164516715.png)]

    @ConditionalOnMissingBean(name = “tom”)//没有tom名字的Bean时,MyConfig类的Bean才能生效。

    @ImportResource

    比如,公司使用bean.xml文件生成配置bean,然而你为了省事,想继续复用bean.xml,@ImportResource粉墨登场。

    @ImportResource("classpath:beans.xml")
    public class MyConfig {
    ...
    }
    
    • 1
    • 2
    • 3
    • 4

    @ConfigurationProperties

    如何使用Java读取到properties文件中的内容,并且把它封装到JavaBean中,以供随时使用

    Spring Boot提供一种配置配置绑定:

    配置绑定@ConfigurationProperties + @Component

    假设有配置文件application.properties

    mycar.name=ok
    mycar.price=100000
    
    • 1
    • 2

    只有在容器中的组件,才会拥有SpringBoot提供的强大功能

    @Component
    @ConfigurationProperties(prefix = "mycar")	//注意mycar和上面配置前缀对应
    public class Car {
    ...
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    配置绑定@EnableConfigurationProperties + @ConfigurationProperties

    1. 开启Car配置绑定功能
    2. 把这个Car这个组件自动注册到容器中

    在配置类上开启car实体类的属性配置功能

    @EnableConfigurationProperties(Car.class)
    public class MyConfig {
    ...
    }
    
    • 1
    • 2
    • 3
    • 4
    @ConfigurationProperties(prefix = "mycar")
    public class Car {
    ... 
    }
    
    • 1
    • 2
    • 3
    • 4
  • 相关阅读:
    Jmeter常用线程组设置策略
    k8s 读书笔记 - 深入掌握 Pod
    windows下gvim的配置
    OPENMP FOR CONSTRUCT GUIDED 调度方式实现原理和源码分析
    java智慧校园信息管理系统源码带微信小程序
    【算法三】冒泡排序
    fastjson首字母大写的几种方法
    Linux 模块管理方法之 DKMS
    十四、流式编程(4)
    Open Office XML 格式中的 Style 设计原理
  • 原文地址:https://blog.csdn.net/a2272062968/article/details/126769195