使用前注意:
在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>我们之前都是使用 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!!!
使用注解注入属性
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; } }我们这些注解,就是替代了在配置文件当中配置步骤而已!更加的方便快捷!
@Component的三个衍生注解
为了更好的进行分层,Spring可以使用其它三个注解,功能一样,目前使用哪一个功能都一样。
controller层: @Controller:
service层 : @Service:
dao层: @Repository
四个注解功能都是一样的,都是代表将某个类注册到Spring中,装配Bean
@scope
singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。
prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收
xml与注解:
xml更加万能,适用于任何场合!维护简单方便注解不是自己类使用不了,维护相对复杂xml与注解整合开发 :推荐最佳实践
xml用来管理bean;注解只负责完成属性的注入;我们在使用的过程中,只需要注意一个问题:必须让注解生效,就需要开启注解的支持 <!--指定要扫描的包,这个包下的注解就会生效--> <context:component-scan base-package="com.jl.pojo"/> <!-- 开启属性注解支持! --> <context:annotation-config/>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