springFrameWork 第五章:IOC 注解-Annotation常用注解

14 篇文章 0 订阅

Annotation常用注解


1)@Component
可以使用此注解描述 Spring 中的 Bean,但它是一个泛化的概念,仅仅表示一个组件(Bean),并且可
以作用在任何层次。使用时只需将该注解标注在相应类上即可。
2)@Repository
用于将数据访问层(DAO层)的类标识为 Spring 中的 Bean,其功能与 @Component 相同。
3)@Service
通常作用在业务层(Service 层),用于将业务层的类标识为 Spring 中的 Bean,其功能与
@Component 相同。
4)@Controller
通常作用在控制层(如 Struts2 的 Action),用于将控制层的类标识为 Spring 中的 Bean,其功能与
@Component 相同。
5)@Autowired
用于对 Bean 的属性变量、属性的 Set 方法及构造函数进行标注,配合对应的注解处理器完成 Bean 的自
动配置工作。默认按照 Bean 的类型进行装配。
@Qualifier
与 @Autowired 注解配合使用,会将默认的按 Bean 类型装配修改为按 Bean 的实例名称装配,Bean 的
实例名称由 @Qualifier 注解的参数指定。

6)@Resource

(从javax.annotation导入, 默认情况下没有, 可在http://www.java2s.com/Code/Jar/j/Downloadjavaxannotation30jar.htm下载)
其作用与 Autowired 一样。其区别在于 @Autowired 默认按照 Bean 类型装配,而 @Resource 默认按照
Bean 实例名称进行装配。
@Resource 中有两个重要属性:name 和 type
Spring 将 name 属性解析为 Bean 实例名称,type 属性解析为 Bean 实例类型。如果指定 name 属性,则
按实例名称进行装配;如果指定 type 属性,则按 Bean 类型进行装配。
如果都不指定,则先按 Bean 实例名称装配,如果不能匹配,则再按照 Bean 类型进行装配;如果都无法匹
配,则抛出 NoSuchBeanDefinitionException 异常。
 

测试案例:

同样我们需要以下几个jar包库:

一.我们写个Dao数据底层类:

package com.ioc;

import org.springframework.stereotype.Repository;

@Repository
public class UserDao {
	public void findUser() {
		System.out.println("-----run user Dao layer -----");
	}
}

通过@Repository 注解,我们能立马知道这个是Dao层。即相当于自动将该类配置到xml文件中。

 

二.需要一个service服务类

package com.ioc;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

@Service
public class UserService {
	
	@Autowired
	private UserDao userDao;
	
	public void findUser() {
		System.out.println("-----run user service -----");
		userDao.findUser();
	}
}

通过@Service将该类加载到配置文件中,然后通过@Autowired配合对应的注解处理器完成 Bean 的自
动配置工作,即完成: private UserDao userDao = new userDao();的功能

第三步:控制层

package com.ioc;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;

@Controller("user")
public class UserController {
	
	@Autowired
	private UserService userService;
	
	public void findUser() {
		System.out.println("-----run user Controller -----");
		userService.findUser();
	}
}

通过@Controller将该类加载到配置文件中,然后通过@Autowired配合对应的注解处理器完成 Bean 的自
动配置工作,即完成: private UserService userService = new UserService();的功能

第五步:需要通过一个配置文件将这几个类全部配置到一起产生联系。

<?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-4.3.xsd
	 http://www.springframework.org/schema/context
	 http://www.springframework.org/schema/context/spring-context.xsd">
	<context:component-scan base-package="com.ioc"/>
</beans>

和之前的配置文件相比,新增了:xmlns:context="http://www.springframework.org/schema/context" 需要context

需要加载的链接源码:

 http://www.springframework.org/schema/context
 http://www.springframework.org/schema/context/spring-context.xsd

配置好后,只需要一句话,就可以装配所有的类:

<context:component-scan base-package="com.ioc"/>

即通过扫描的方式装配所有类。

 

写一个测试类进行测试

package com.ioc;

import static org.junit.jupiter.api.Assertions.*;

import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;

class TestUserController {

	@Test
	void testFindUser() {
		ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml");
		UserController userController = context.getBean("user", UserController.class);
		userController.findUser();
	}

}

 

测试结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逼哥很疯狂

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值