Spring中常用注解:
名称 | 说明 |
@Component | 标识为Spring中的Bean,可以作用在任何层次。 |
@Repository | 用于数据访问层(Dao层)的类,功能与@Component相同。 |
@Service | 业务层(Service层),功能与@Component相同。 |
@Controller | 控制层(如:Spring MVC 的 Controller),功能与@Component相同。 |
@Autowried | 对Bean的属性变量,属性的setter方法及构造方法进行标注,完成Bean的自动配置工作。默认按照Bean类型装配。 |
@Resource | 与@Autowried作用相同。默认按照Bean实例名称装配。具有两个重要属性name、type。 不匹配抛出NoSuchBeanDefinitionException异常 |
@Qualifier | 与@Autowried配合使用,将默认按Bean类型装配修改为按Bean实例名称装配,名称由@Qualifier的参数指定。 |
第一步:创建UserDao接口,定义say1()方法
package com.ithema.annotation;
public interface UserDao {
//定义say1()方法
public void say1();
}
第二步:创建UserDao接口的实现类UserDaoImpl
package com.ithema.annotation;
import org.springframework.stereotype.Repository;
/*
* 使用@Repository注解将UserDaoImpl类标识为Spring中的Bean
* 相当于XML配置文件<bean id="..." class="...">
*/
@Repository("userDao")
public class UserDaoImpl implements UserDao{
@Override
public void say1() {
/*
* 在say1()方法中输出字符,检测是否执行了该方法
*/
System.out.println("这里是UserDaoImpl由,UserServiceImpl调用");
}
}
第三步:创建一个UserService接口,并定义say2()方法
package com.ithema.annotation;
public interface UserService {
public void say2();
}
第四步:创建UserService接口的实现类UserServiceImpl,实现接口中的say2()方法
package com.ithema.annotation;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
/*
* @Service注解将UserServiceImpl类,标识为Spring中的Bean
* 相当于XML配置文件<bean id="..." class="..." />
*/
@Service("userService")
public class UserServiceImpl implements UserService {
/*
* 对Bean的属性变量,属性的setter方法及构造方法进行标注,完成Bean的自动配置工作。默认按照Bean类型装配。
* 相当于XML配置文件<property name="userDao" ref="userDao"></property>
*/
@Resource(name="userDao")
private UserDao userDao;
@Override
public void say2() {
// TODO Auto-generated method stub
/*
* 调用userDao中的say1()方法,并syso输出打印,检测是否进入了UserServiceImpl
*/
this.userDao.say1();
System.out.println("这里是userService...Say2()...");
}
}
第五步:
package com.ithema.annotation;
import javax.annotation.Resource;
import org.springframework.stereotype.Controller;
/*
* 使用@Controller注解,标注了UserController类,
* 相当于XML配置文件<bean id="" class="" />
*/
@Controller("userController")
public class UserController {
/*
* @Resource注解,标注在userService属性上
* 相当于XML配置文件<property name="userService" ref="userService"/>
*/
@Resource(name="userService")
private UserService userService;
public void say3() {
//调用userService中的say2()方法
this.userService.say2();
//输出字符串,检测是否进入了UserController
System.out.println("这里是userController");
}
}
第六步:创建XML配置文件
<?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-4.3.xsd">
<!-- 使用 context 命名空间,在配置文件中开启相应的注解处理器 -->
<!-- <context:annotation-config></context:annotation-config> -->
<!-- 分别定义三个Bean实例 -->
<!--
<bean id="userDao" class="com.ithema.annotation.UserDaoImpl"></bean>
<bean id="userService" class="com.ithema.annotation.UserServiceImpl"></bean>
<bean id="userController" class="com.ithema.annotation.UserController"></bean>
-->
<!-- 使用scan扫描,省去了一个一个的定义 -->
<context:component-scan base-package="com.ithema.annotation"></context:component-scan>
</beans>
第七步:创建测试类AnnotationAssembleTest
package com.ithema.annotation;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class AnnotationAssembleTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
//定义配置文件路径
String xmlPath="com/ithema/annotation/beans6.xml";
//加载配置文件
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(xmlPath);
//System.out.println(applicationContext.getBean(arg0));
//获取UserController实例
UserController userController = (UserController) applicationContext.getBean("userController");
//调用UserController中say3()方法
userController.say3();
}
}