1 为什么使用注解开发
Spring本身就是一个轻代码而重配置的框架,配置比较繁重,影响开发效率,所以就在Spring中加入了注解,使用注解代替原来的xml配置文件,这样就可以简化配置,提升开发效率。
2 Spring中的常用注解
@Component:使用在类上用于实例化Bean
@Controller:使用在web层类上用于实例化Bean(作用于@Component一致)
@Service:使用在service层类上用于实例化Bean(作用于@Component一致)
@Repository:使用在dao层类上用于实例化Bean(作用于@Component一致)
@Autowired:使用在字段上用于根据类型依赖注入
@Qualifier:结合@Autowired一起使用用于根据名称进行依赖注入
@Resource:相当于@Autowired+@Qualifier,按照名称进行注入
@Value:注入普通属性
@Scope:标注Bean的作用范围
@PostConstruct:使用在方法上标注该方法是Bean的初始化方法
@PreDestroy:使用在方法上标注该方法是Bean的销毁方法
以上的这些注解主要是替代 Bean 标签的配置。但是这些注解还不能全部替代xml配置文件,包括以下几个新注解:
@Configuration:用于指定当前类是一个Spring 配置类,当创建容器时会从该类上加载注解
@ComponentScan:用于指定Spring 在初始化容器时要扫描的包
@Bean:使用在方法上,标注将该方法的返回值存储到Spring 容器中
@PropertySource:用于加载.properties 文件中的配置
@Import:用于导入其他配置类
3 使用注解代替XML文件配置
使用注解进行开发时,需要在核心配置文件中配置组件扫描,作用是指定哪个包及其子包下的Bean需要进行扫描以便识别使用注解配置的类、字段和方法。
也就是告诉Spring在这些包下面使用了注解,运行的时候需要扫描
<context:component-scan base-package="com.wang"></context:component-scan>
base-package就是指向使用注解的包
3.1 代替 Bean 标签的注解
id:Bean实例在Spring容器中的唯一标识;
class:配置Bean的全包名(全限定名);
scope:配置对象的作用范围;
init-method:指定类中的初始化方法名称;
destroy-method:指定类中销毁方法名称
现在我们就使用注解的方式来代替xml文件中 Bean 标签的配置。
3.2 @Component代替id和class属性
在xml中将一个类交给Spring容器管理的配置是这样的:
<bean id="userDao" class="com.wang.dao.impl.UserDaoImpl"></bean>
使用@Component注解后是这样的(直接在对应类上面加上@Component即可)
//<bean id="userDao" class="com.wang.dao.impl.UserDaoImpl"></bean>
@Component("userDao")
public class UserDaoImpl implements UserDao {
【注】: 对于@Controller、@Service、@Repository三个注解,他们的作用与@Component注解是一致的,只是一个语义化的表达,体现出我们的三层架构(即@Controller对应controller层的类、@Service对应service层的类、@Repository对应dao层的类)
@Autowired、@Qualifier、@Resource代替字标签 property的依赖注入
xml文件中的依赖注入如下:
<bean id="userService" class="com.wang.service.impl.UserServiceImpl">
<property name="userDao" ref="userDao"></property>
</bean>
使用注解代替如下:
@Resource注解相当于于@Autowired+@Qualifier注解,按照名称进行注入
3.3 @Value代替property普通属性注入
xml中的值注入:
<bean id="user" class="com.wang.pojo.User">
<property name="username" value="test"/>
<property name="password" value="testPassword"/>
</bean>
使用注解后的值注入:
@Component("user")
public class User {
private Integer id;
@Value("test")
private String username;
@Value("testPassword")
private String password;
}
3.4 @Scope注解代替scope属性标注Bean的范围
xml中scope属性标注Bean范围
<bean id="userDao" class="com.wang.dao.impl.UserDaoImpl" scope="prototype"></bean>
使用@Scope注解标注Bean范围
3.5 @PostConstruct、@PreDestroy注解代替init-method、destroy-method属性配置
xml中配置Bean的初始化方法和销毁方法。
<bean id="user" class="com.wang.pojo.User" init-method="start" destroy-method="end"></bean>
@PostConstruct、@PreDestroy注解配置Bean的初始化方法和销毁方法
@PostConstruct
public void start(){
System.out.println("初始化方法");
}@PreDestroy
public void end(){
System.out.println("销毁方法");
}
4 代替其他标签的注解
4.1 @Configuration
学习下面几个注解需要先创建一个类,并在该类上加@Configuration注解,表明该类是一个Spring的核心配置文件,以代替applicationContext.xml
@Configuration //标志该类为Spring的核心配置类
public class SpringConfig {}
4.2 @ComponentScan代替context:component-scan配置包扫描
xml中配置包扫描:
<context:component-scan base-package="com.wang"></context:component-scan>
配置类中配置包扫描:
@Configuration //标志该类为Spring的核心配置类
@ComponentScan("com.wang")
public class SpringConfig {}
4.3 @Bean代替非自定义的Bean的配置
xml中配置数据源如下
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&serverTimezone=Asia/Shanghai"/>
<property name="username" value="root"/>
<property name="password" value="123456"/>
</bean>
4.4 @PropertySource代替context:property-placeholder加载外部properties配置文件
xml中加载.properties 文件中的配置
<context:property-placeholder location="jdbc.properties"/>
配置类中加载.properties 文件中的配置
配置的内容
@Configuration //标志该类为Spring的核心配置类
@ComponentScan("com.wang")
@PropertySource("jdbc.properties")
public class SpringConfig {@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.username}")
private String username;
@Value("${jdbc.password}")
private String password;@Bean("dataSource")
public DataSource getDataSource(){
DruidDataSource dataSource = new DruidDataSource();
dataSource.setDriverClassName(driver);
dataSource.setUrl(url);
dataSource.setUsername(username);
dataSource.setPassword(password);
return dataSource;
}
}