8、Spring:使用Spring注解开发

tech2025-03-04  8

文章目录

1、使用前准备2、Bean的实现3、属性注入4、衍生注解5、作用域6、小结7、基于Java类进行配置

1、使用前准备

使用前注意:

在spring4之后,要使用注解开发,必须保证aop的包成功导入 所需依赖: <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.0.RELEASE</version> </dependency>

使用注解需要导入context约束,增加注解的支持!

<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd"> <!-- 开启属性注解支持! --> <context:annotation-config/> </beans>

2、Bean的实现

我们之前都是使用 bean 的标签进行bean注入,但是实际开发中,我们一般都会使用注解!

1、指定注解扫描的包

<!--指定要扫描的包,这个包下的注解就会生效--> <context:component-scan base-package="com.jl.pojo"/>

2、在指定包下编写类,增加注解

package com.jl.pojo; import org.springframework.stereotype.Component; //@Component 组件 等价于 <bean id="user" class="com.jl.pojo.User"/> @Component public class User { public String name = "张三"; }

3、测试

package com.jl.test; import com.jl.pojo.User; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class Test { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); User user = (User) context.getBean("user"); System.out.println(user.name); } }

小结:

@Component:组件,放在类上,说明这个类被Spring管理了,就是bean!!!

3、属性注入

使用注解注入属性

1、可以不用提供set方法,直接在属性名上添加@value(“值”)

package com.jl.pojo; import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component; //@Component 组件 等价于 <bean id="user" class="com.jl.pojo.User"/> @Component public class User { @Value("hh") // 等价于 <property name="name" value="hh"/> public String name; }

2、如果提供了set方法,在set方法上添加@value(“值”);

//@Component 组件 等价于 <bean id="user" class="com.jl.pojo.User"/> @Component public class User { public String name; @Value("hh") public void setName(String name) { this.name = name; } }

4、衍生注解

我们这些注解,就是替代了在配置文件当中配置步骤而已!更加的方便快捷!

@Component的三个衍生注解

为了更好的进行分层,Spring可以使用其它三个注解,功能一样,目前使用哪一个功能都一样。

controller层: @Controller:

service层 : @Service:

dao层: @Repository

四个注解功能都是一样的,都是代表将某个类注册到Spring中,装配Bean

5、作用域

@scope

singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。

prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收

6、小结

xml与注解:

xml更加万能,适用于任何场合!维护简单方便注解不是自己类使用不了,维护相对复杂

xml与注解整合开发 :推荐最佳实践

xml用来管理bean;注解只负责完成属性的注入;我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持 <!--指定要扫描的包,这个包下的注解就会生效--> <context:component-scan base-package="com.jl.pojo"/> <!-- 开启属性注解支持! --> <context:annotation-config/>

7、基于Java类进行配置

JavaConfig 原来是 Spring 的一个子项目,它通过 Java 类的方式提供 Bean 的定义信息,在 Spring4 的版本, JavaConfig 已正式成为 Spring4 的核心功能 。

测试:

1、编写一个实体类,Dog

@Component //将这个类标注为Spring的一个组件,放到容器中! public class Dog { public String name = "dog"; }

2、新建一个config配置包,编写一个MyConfig配置类

@Configuration //代表这是一个配置类 public class MyConfig { @Bean //通过方法注册一个bean,这里的返回值就Bean的类型,方法名就是bean的id! public Dog dog(){ return new Dog(); } }

3、测试

@Test public void test2(){ ApplicationContext applicationContext = new AnnotationConfigApplicationContext(MyConfig.class); Dog dog = (Dog) applicationContext.getBean("dog"); System.out.println(dog.name); }

4、成功输出结果!

导入其他配置如何做呢?

1、我们再编写一个配置类!

@Configuration //代表这是一个配置类 public class MyConfig2 { }

2、在之前的配置类中我们来选择导入这个配置类

@Configuration @Import(MyConfig2.class) //导入合并其他配置类,类似于配置文件中的 inculde 标签 public class MyConfig { @Bean public Dog dog(){ return new Dog(); } }

关于这种Java类的配置方式,我们在之后的SpringBoot 和 SpringCloud中还会大量看到,我们需要知道这些注解的作用即可!

视频链接:https://www.bilibili.com/video/BV1WE411d7Dv?p=14

最新回复(0)