8_基于注解方式

是什么

注解是代码特殊标记,格式:@注解名称(属性名称=属性值, 属性名称=属性值…)

怎么做

使用注解,注解作用在类上面,方法上面,属性上面

能干嘛

使用注解目的:简化 xml 配置


Spring 针对 Bean 管理中创建对象提供注解

(1)@Component
(2)@Service
(3)@Controller
(4)@Repository

上面四个注解功能是一样的,都可以用来创建 bean 实例

只是为了开发人员好进行区分,所以使用不同的名字,效果是一样的

基于注解方式实现对象创建

第一步 引入依赖

在这里插入图片描述

第二步 开启组件扫描

<!--开启组件扫描
 1 如果扫描多个包,多个包使用逗号隔开
 2 扫描包上层目录
-->
<context:component-scan base-package="com.atguigu"></context:component-scan>

第三步 创建类,在类上面添加创建对象注解

//在注解里面 value 属性值可以省略不写,
//默认值是类名称,首字母小写
//UserService -- userService
@Component(value = "userService") //<bean id="userService" class=".."/>
public class UserService {
	 public void add() {
	 	System.out.println("service add.......");
 	}
}

测试

@Test
public void testService1() {
    ApplicationContext context = new ClassPathXmlApplicationContext("bean1.xml");
    UserService userService = context.getBean("userService", UserService.class);
    System.out.println(userService);
    userService.add();
}

Spring 先加载配置文件,发现需要扫描包,去包中进行扫描,在类中扫描到相应的注解,创建对象

开启组件扫描细节配置

配置扫描指定内容

<!--示例 1
 use-default-filters="false" 表示现在不使用默认 filter,自己配置 filter
 context:include-filter ,设置扫描哪些内容
-->
<context:component-scan base-package="com.atguigu" use-defaultfilters="false">
 	<context:include-filter type="annotation"expression="org.springframework.stereotype.Controller"/>
</context:component-scan>

配置不扫描哪些内容

<!--示例 2
 下面配置扫描包所有内容
 context:exclude-filter: 设置哪些内容不进行扫描
-->
<context:component-scan base-package="com.atguigu">
   <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>

基于注解方式实现属性注入

(1)@Autowired

(2)@Qualifier

(3)@Resource

(4)@Value

@Autowired

@Autowired:根据属性类型进行自动装配

第一步 把 service 和 dao 对象创建,在 service 和 dao 类添加创建对象注解
第二步 在 service 注入 dao 对象,在 service 类添加 dao 类型属性,在属性上面使用注解

public interface UserDao {
    public void add();
}
@Repository
public class UserDaoImpl implements UserDao {
    @Override
    public void add() {
        System.out.println("dao add.....");
    }
}
@Service
public class UserService {

    //定义dao类型属性
    //不需要添加set方法
    //添加注入属性注解
    @Autowired  //根据类型进行注入
    private UserDao userDao;
    
    public void add() {
        System.out.println("service add......."+name);
        userDao.add();
    }
}

根据类型进行注入,如果有多个对象,此时需要指定名称

@Qualifier

@Qualifier:根据名称进行注入

这个@Qualifier 注解的使用,和上面@Autowired 一起使用

在实现类上指定名称

@Repository(value = "userDaoImpl1")
public class UserDaoImpl implements UserDao {
    @Override
    public void add() {
        System.out.println("dao add.....");
    }
}
@Service
public class UserService {

    //定义dao类型属性
    //不需要添加set方法
    //添加注入属性注解
	@Autowired //根据类型进行注入
	@Qualifier(value = "userDaoImpl1") //根据名称进行注入
	private UserDao userDao;
    
    public void add() {
        System.out.println("service add......."+name);
        userDao.add();
    }
}

@Resource

可以根据类型注入,可以根据名称注入

该注解并非是 Spring 官方提供,而是 java web 提供

import javax.annotation.Resource;
//@Resource //根据类型进行注入
@Resource(name = "userDaoImpl1") //根据名称进行注入
private UserDao userDao;

@Value

@Value:注入普通类型属性

@Value(value = "abc")
private String name;

解决了在 xml 配置文件中使用 bean 创建对象 ,set 注入属性,但我们依然还需要 xml 配置文件,进行扫描包的配置,

此时可以使用下列注解方式进行替代

完全注解开发

(1)@Configuration
(2)@ComponentScan

(1)创建配置类,替代 xml 配置文件

@Configuration //作为配置类,替代 xml 配置文件
@ComponentScan(basePackages = {"com.atguigu"})
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();
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值