Spring-05 使用注解开发 使用注解开发 1.项目准备
在spring4之后,想要使用注解形式,必须得要引入aop的包5
<!-- https://mvnrepository.com/artifact/org.springframework/spring-aop --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>5.3.3</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 "> </beans> 2.Bean实现我们之前都是使用 bean 的标签进行bean注入,但是实际开发中,我们一般都会使用注解!
1、配置扫描哪些包下的注解
<context:component-scan base-package="pojo"/>2、在指定包下编写类,增加注解
// 相当于配置文件中 <bean/> @Component("user") public class User { public String name = "zc"; }3.测试
@Test public void UserTest(){ ApplicationContext applicationContext = new ClassPathXmlApplicationContext("bean.xml"); User user = (User) applicationContext.getBean("user"); System.out.println(user.name); } 3.属性注入 3.1 不提供set方法可以不提供set方法,直接在属性名上添加@value(“xxx”)
@Component("user") public class User { // 相当于配置文件中 <property value="秦疆"/> @Value("zc") public String name; }测试结果成功
3.1 提供了set方法如果提供了set方法,在set方法上添加@value(“xxx”)
@Component("user") public class User { public String name; @Value("zc") public void setName(String name) { this.name = name; } }测试结果成功
4.衍生注解我们这些注解,就是替代了在配置文件当中配置步骤而已!更加的方便快捷!
@Component三个衍生注解
为了更好的进行分层,Spring可以使用其它三个注解,功能一样,目前使用哪一个功能都一样。
@Controller:web层
@Service:service层
@Repository:dao层
写上这些注解,就相当于将这个类交给Spring管理装配了!
作用域
@scope
singleton:默认的,Spring会采用单例模式创建这个对象。关闭工厂 ,所有的对象都会销毁。
prototype:多例模式。关闭工厂 ,所有的对象不会销毁。内部的垃圾回收机制会回收
@Component("user") @Scope("prototype") public class User { @Value("zc") public String name; }总结
XML与注解比较
XML可以适用任何场景 ,结构清晰,维护方便
注解不是自己提供的类使用不了,开发简单方便
xml与注解整合开发 :推荐最佳实践
xml管理Bean
注解完成属性注入
使用过程中, 可以不用扫描,扫描是为了类上的注解
<context:annotation-config/>作用:
进行注解驱动注册,从而使注解生效
用于激活那些已经在spring容器里注册过的bean上面的注解,也就是显示的向Spring注册
如果不扫描包,就需要手动配置bean
如果不加注解驱动,则注入的值为null
5.使用java的方式配置Spring我们现在要完全不使用spring的xml配置,全权交给java来做。
5.1 实体类 @Controller public class UserT { // 属性的注入 @Value("zcT") private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "User{" + "name='" + name + '\'' + '}'; } } 5.2 配置类@Configuration:本质上也是一个Controller,也会被spring托管,注册到容器中
@Configuration:表示这是一个配置类,和之前的beans.xml的功能一样的
@ComponentScan:表示组件的扫描
@import:导入其他的配置类
@Bean:表示注册一个bean
@Configuration @ComponentScan("pojo") public class MyConfig { // 方法的名字即是bean中的id // 方法的返回值就是bean中的class @Bean public UserT getUserT(){ return new UserT(); // return就是返回要注入到bean中的对象 } } 5.3 测试 @Test public void UserTTest(){ ApplicationContext context = new AnnotationConfigApplicationContext(MyConfig.class); UserT userT = (UserT) context.getBean("getUserT"); System.out.println(userT.toString()); } 代理模式为什么要学习代理模式,因为AOP的底层机制就是动态代理。
代理模式:
静态代理
动态代理
1.静态代理角色分析
抽象角色 : 一般使用接口或者抽象类来实现
真实角色 : 被代理的角色
代理角色 : 代理真实角色 ; 代理真实角色后 , 一般会做一些附属的操作