什么是注解
(1)注解是代码的特殊标记
格式:@注解名称(属性名称=属性值,属性名称=属性值,…)
(2)注解可以作用在类上面,方法上面,属性上面
(3)使用注解的目的:为了简化xml配置
Spring中bean管理中创建对象提供的注解
@Component
@Service
@Controller
@Repository
说明:上面四个注解功能都是一样的,都可以用来创建bean实例,习惯把每个注解用在不同的层中,使我们更加清晰明白当前组件所扮演的角色
基于注解方式实现对象的创建
第一步:引入依赖
第二步:在spring的配置文件中开启组件扫描
<?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
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<!--开启组件扫描:自动扫描这个包,这个包下面的注解都会生效-->
<context:component-scan base-package="com.feng"/>
<!--
总结:
xml与注解:
xml更加万能,适用于任何场合,维护简单方便
注解不是自己的使用不了,维护相对复杂
xml与注解最佳实践
xml用来管理bean
注解只负责完成属性的注入
-->
</beans>
/*
* @Component 组件
* 等价于<baen id="user" class="com.feng.pojo.User"/>
* */
/*
* @Component衍生注解,我们在web开发中,会按照mvc三层架构分层
* dao @Repository
* controller @Controller
* service @Service
* 这四个注解功能都是一样的,都是代表某个类注册到Spring中,装配bean
* */
//value就相当于bean标签中的id属性
//value可以省略;省略了默认值就是类名首字母小写
@Component(value = "user")
public class User {
//相当于<property name="name" value="汤姆"/>
@Value("汤姆")
public String name;
}
延伸
<!--延伸1
use-default-filters="false"表示不使用默认filter,使用自己配置的filter
context:include-filter设置扫描那些内容
-->
<!--只会扫描Controller注解的类-->
<context:component-scan base-package="com.feng" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!--延伸2
context:exclude-filter设置那些内容不扫描
-->
<!--扫描除了Controller注解的其他注解类-->
<context:component-scan base-package="com.feng">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
基于注解实现属性注入
(1)@Autowired:根据属性类型进行自动装配
第一步:创建service和dao对象,在service和dao类添加创建对象注解
第二步:在service注入dao对象,在dao属性上面使用注解
UserDao接口
public interface UserDao {
public void add();
}
UserDao接口实现类
@Repository
public class UserDaoImpl implements UserDao {
public void add() {
System.out.println("dao add...");
}
}
UserService类
@Service
public class UserService {
//不需要添加set方法
@Autowired
private UserDao userDao;
public void add(){
System.out.println("service add...");
userDao.add();
}
}
测试类
public class MyTest {
@Test
public void test1(){
ApplicationContext context =
new ClassPathXmlApplicationContext("applicationContext.xml");
UserService userService = context.getBean("userService",UserService.class);
userService.add();
}
}
结果:
service add…
dao add…
(2)@Qualifier:根据属性名进行注入(要配合着@Autowired一起使用)
在UserDao接口有多个实现类的情况下
注意:在@Qualifier(value=""),value的值是:注解创建对象时的value,没有value就是默认首字母小写。
UserDao接口的UserDaoImpl1 类
@Repository(value="userDaoImpl1")
public class UserDaoImpl1 implements UserDao{
public void add() {
System.out.println("dao1 add...");
}
}
UserService类
@Service
public class UserService {
//不需要添加set方法
@Autowired
@Qualifier(value = "userDaoImpl1")
private UserDao userDao;
public void add(){
System.out.println("service add...");
userDao.add();
}
}
测试类不变,结果:
service add…
dao1 add…
(3)@Resource:可以根据类型注入,也可以根据名称注入(它是javax(扩展包)里面的类)
//@Resource//根据类型注入
@Resource(name = "userDaoImpl1")//根据类型注入
private UserDao userDao;
(4)@Value:注入普通类型属性
@value(value = "Tom")
private String name;