4.1、注解概述
1、什么是注解
-
注解是代码特殊标记,
-
格式:
@注解名称(属性名称=属性值,属性名称=属性值...)
-
使用注解,注解作用在类方面,方法上面,属性上面
-
使用注解目的:简化
xml
配置
4.2、基于注解方式创建对象
1、Spring
针对 Bean
管理中创建对象提供注解
@Component
@Service
@Controller
@Repository
上面四个注解功能是一样的,都可以用来创建
bean
实例
2、基于注解方式实现对象创建
(1)第一步:引入依赖(在spring
安装包下的libs
文件下寻找此jar
包放到项目中)
(2)第二步:开启组件扫描
-
引入
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"> </beans>
-
开启组件扫描
<!--开启组件扫描 1、如果扫描多个包,多个包之间使用,隔开 <context:component-scan base-package="com.ssm.spring5.DAO,com.ssm.spring5.service"></context:component-scan> 2、扫描那个包上层目录 --> <context:component-scan base-package="com.ssm.spring5"></context:component-scan>
(3)第三步:创建类,在类上面添加创建对象注解
【UserService.java】
//在注解里面value属性值可以省略不写
//默认值是类名称,首字母小写
//UserService -> userService
@Component(value = "userService") //类似于<bean id="userService" class=".." />
public class UserService {
public void add() {
System.out.println("service add...");
}
}
3、代码测试:
@Test
public void testService() {
ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");
UserService userService = context.getBean("userService", UserService.class);
System.out.println(userService);
userService.add();
}
4、开启组件扫描细节配置
<!--示例1
use-default-filters="false"表示选择不使用默认filter,自己配置filter
context:include-filter,设置扫描哪些内容
-->
<context:component-scan base-package="com.ssm" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!--示例2
use-default-filters="false"表示选择不使用默认filter,自己配置filter
context:exclude-filter,设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.ssm">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
4.3、基于注解方式实现属性注入
4.3.1、@AutoWired
1、@AutoWired
:根据属性类型进行自动装配
2、@AutoWired
实现属性注入
(1)第一步:把service
和DAO
对象创建,在service
和DAO
类添加创建对象注解
【UserDAOImpl.java】
@Repository
public class UserDAOImpl implements UserDAO{
@Override
public void add() {
System.out.println("DAO add...");
}
}
(2)第二步:在service
注入DAO
对象,在service
类添加DAO
类型属性,在属性上面使用注解
【UserService.java】
@Service
public class UserService {
//定义DAO类型属性
//不需要添加set方法
//添加注入属性注解
@Autowired
private UserDAO userDAO;
public void add() {
System.out.println("service add...");
userDAO.add();
}
}
4.3.2、@Qualifier
1、@Qualifier
:根据属性名称进行注入
2、这个@Qualifier
注解的使用与上面@AutoWired
一起使用
3、代码演示:
【UserDAOImpl.java】
@Repository(value = "userDAOImpl1")
public class UserDAOImpl implements UserDAO{
@Override
public void add() {
System.out.println("DAO add...");
}
}
【UserService.java】
@Service
public class UserService {
//定义DAO类型属性
//不需要添加set方法
//添加注入属性注解
@Autowired
//若有多个类型的话,需要指定名称注入
@Qualifier(value = "userDAOImpl1")
private UserDAO userDAO;
public void add() {
System.out.println("service add...");
userDAO.add();
}
}
4.3.3、@Resource
1、@Resource
:可以根据类型进行注入,可以根据名称进行注入
2、代码演示:
【UserService.java】
@Service
public class UserService {
//@Resource//根据类型进行注入
@Resource(name = "userDAOImpl1")//根据名称进行注入
private UserDAO userDAO;
public void add() {
System.out.println("service add...");
userDAO.add();
}
}
4.3.4、@Value
1、@Value
:注入普通类型属性
@Service
public class UserService {
@Value(value = "abc")
private String uname;
public void add() {
System.out.println("uname:" + uname);
userDAO.add();
}
}
4.4、完全注解开发
1、创建配置类,替代xml
配置文件
//作为配置类,替代xml配置文件
@Configuration
@ComponentScan(basePackages = {"com.ssm"})
public class SpringConfig {
}
2、编写测试类
@Test
public void testService2() {
//加载配置类
ApplicationContext context = new AnnotationConfigApplicationContext(SpringConfig.class);
UserService userService = context.getBean("userService", UserService.class);
System.out.println(userService);
userService.add();
}