Spring常用annotation标签
2015-09-22 14:54
597 查看
转自:http://blog.163.com/pomelo_orange/blog/static/199328089201371592654687/
@org.springframework.stereotype.Service
表示当前类受Spring控制,由Spring 负责该类的实例创建和销毁工作。可以在其他类中通过IOC机制注入。
位置:使用于类级别
参数:name-在Spring 中注册的名称,默认为第一个字母小写的类名。建议不指定名称。
样例:
使用默认的BeanName:@Service
指定BeanName:@Service(“beanName”)
@org.springframework.context.annotation.Scope
当前类在Spring 中创建实例的有效范围,可以是单例,或每次创建一个新的实例,或是每个session创建一个实例。Spring默认为单实例,如果没有特殊需要可以不设置此标签。
位置:使用于类级别
参数:value-实例的有效范围
样例:
单实例:@Scope("singleton")
每次创建新实例:@Scope("prototype")
Session 范围实例:@Scope("session")
@org.springframework.transaction.annotation.Transactional
启动事务控制,写入该标签后可以启动事务控制。
位置:使用于类级别或方法级别,建议使用在方法级别上。
参数:readOnly -是否是只读事务,默认为false
样例:@Transactional(readOnly = false)
@org.springframework.beans.factory.annotation.Autowired
自动装配标签,用于IOC注入,可以根据类型获取相应实例。
位置:使用于类变量或setter方法,可以不是public作用域。
参数:required – 是否必须设置,默认为true
样例:@Autowired
@org.springframework.beans.factory.annotation.Qualifier
和@Autowired配合使用,可以指定@Autowired标签注入的BeanName,如不指定根据类型自动查询实例注入。
位置:使用于类变量或setter方法,可以不是public作用域
参数:String,Bean的名称
样例:@Qualifier("sessionFactoryXsmfms")
@javax.annotation.PostConstruct
Spring在创建实例时执行的初始化动作。
位置:使用于方法级别
参数:无
@javax.annotation.PreDestroy
Spring在销毁实例时执行的清理动作。
位置:使用于方法级别
参数:无
转自:/article/9533775.html
很长时间没做web项目都把以前学的那点框架知识忘光了,今天把以前做的一个项目翻出来看一下发现用·@Component标记一个组件,而网上有的用@Service标记组件,我晕就查了一下资料:
Spring 2.5 中除了提供 @Component 注释外,还定义了几个拥有特殊语义的注释,它们分别是:@Repository、@Service 和 @Controller。
在目前的 Spring 版本中,这 3 个注释和 @Component 是等效的,但是从注释类的命名上,很容易看出这 3 个注释分别和持久层、业务层和控制层(Web 层)相对应。
虽然目前这3 个注释和 @Component 相比没有什么新意,但 Spring 将在以后的版本中为它们添加特殊的功能。
所以,如果 Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用上述注解对分层中的类进行注释。
@Service用于标注业务层组件
@Controller用于标注控制层组件(如struts中的action)
@Repository用于标注数据访问组件,即DAO组件
@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
[java] view
plaincopy
@Service
public class VentorServiceImpl implements iVentorService {
}
@Repository
public class VentorDaoImpl implements iVentorDao {
}
在一个稍大的项目中,如果组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找以及维护起来也不太方便。
Spring2.5为我们引入了组件自动扫描机制,他在类路径下寻找标注了上述注解的类,并把这些类纳入进spring容器中管理。
它的作用和在xml文件中使用bean节点配置组件时一样的。要使用自动扫描机制,我们需要打开以下配置信息:
代码
[html] view
plaincopy
<?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-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<context:component-scan base-package=”com.eric.spring”>
</beans>
1.component-scan标签默认情况下自动扫描指定路径下的包(含所有子包),将带有@Component、@Repository、@Service、@Controller标签的类自动注册到spring容器。对标记了 Spring's @Required、@Autowired、JSR250's @PostConstruct、@PreDestroy、@Resource、JAX-WS's @WebServiceRef、EJB3's @EJB、JPA's @PersistenceContext、@PersistenceUnit等注解的类进行对应的操作使注解生效(包含了annotation-config标签的作用)。
getBean的默认名称是类名(头字母小写),如果想自定义,可以@Service(“aaaaa”)这样来指定。
这种bean默认是“singleton”的,如果想改变,可以使用@Scope(“prototype”)来改变。
可以使用以下方式指定初始化方法和销毁方法:
[java] view
plaincopy
@PostConstruct
public void init() {
}
@PreDestroy
public void destory() {
}
注入方式:
把DAO实现类注入到action的service接口(注意不要是service的实现类)中,注入时不要new 这个注入的类,因为spring会自动注入,如果手动再new的话会出现错误,
然后属性加上@Autowired后不需要getter()和setter()方法,Spring也会自动注入。
在接口前面标上@Autowired注释使得接口可以被容器注入,如:
[java] view
plaincopy
@Autowired
@Qualifier("chinese")
private Man man;
当接口存在两个实现类的时候必须使用@Qualifier指定注入哪个实现类,否则可以省略,只写@Autowired。
@org.springframework.stereotype.Service
表示当前类受Spring控制,由Spring 负责该类的实例创建和销毁工作。可以在其他类中通过IOC机制注入。
位置:使用于类级别
参数:name-在Spring 中注册的名称,默认为第一个字母小写的类名。建议不指定名称。
样例:
使用默认的BeanName:@Service
指定BeanName:@Service(“beanName”)
@org.springframework.context.annotation.Scope
当前类在Spring 中创建实例的有效范围,可以是单例,或每次创建一个新的实例,或是每个session创建一个实例。Spring默认为单实例,如果没有特殊需要可以不设置此标签。
位置:使用于类级别
参数:value-实例的有效范围
样例:
单实例:@Scope("singleton")
每次创建新实例:@Scope("prototype")
Session 范围实例:@Scope("session")
@org.springframework.transaction.annotation.Transactional
启动事务控制,写入该标签后可以启动事务控制。
位置:使用于类级别或方法级别,建议使用在方法级别上。
参数:readOnly -是否是只读事务,默认为false
样例:@Transactional(readOnly = false)
@org.springframework.beans.factory.annotation.Autowired
自动装配标签,用于IOC注入,可以根据类型获取相应实例。
位置:使用于类变量或setter方法,可以不是public作用域。
参数:required – 是否必须设置,默认为true
样例:@Autowired
@org.springframework.beans.factory.annotation.Qualifier
和@Autowired配合使用,可以指定@Autowired标签注入的BeanName,如不指定根据类型自动查询实例注入。
位置:使用于类变量或setter方法,可以不是public作用域
参数:String,Bean的名称
样例:@Qualifier("sessionFactoryXsmfms")
@javax.annotation.PostConstruct
Spring在创建实例时执行的初始化动作。
位置:使用于方法级别
参数:无
@javax.annotation.PreDestroy
Spring在销毁实例时执行的清理动作。
位置:使用于方法级别
参数:无
转自:/article/9533775.html
很长时间没做web项目都把以前学的那点框架知识忘光了,今天把以前做的一个项目翻出来看一下发现用·@Component标记一个组件,而网上有的用@Service标记组件,我晕就查了一下资料:
Spring 2.5 中除了提供 @Component 注释外,还定义了几个拥有特殊语义的注释,它们分别是:@Repository、@Service 和 @Controller。
在目前的 Spring 版本中,这 3 个注释和 @Component 是等效的,但是从注释类的命名上,很容易看出这 3 个注释分别和持久层、业务层和控制层(Web 层)相对应。
虽然目前这3 个注释和 @Component 相比没有什么新意,但 Spring 将在以后的版本中为它们添加特殊的功能。
所以,如果 Web 应用程序采用了经典的三层分层结构的话,最好在持久层、业务层和控制层分别采用上述注解对分层中的类进行注释。
@Service用于标注业务层组件
@Controller用于标注控制层组件(如struts中的action)
@Repository用于标注数据访问组件,即DAO组件
@Component泛指组件,当组件不好归类的时候,我们可以使用这个注解进行标注。
[java] view
plaincopy
@Service
public class VentorServiceImpl implements iVentorService {
}
@Repository
public class VentorDaoImpl implements iVentorDao {
}
在一个稍大的项目中,如果组件采用xml的bean定义来配置,显然会增加配置文件的体积,查找以及维护起来也不太方便。
Spring2.5为我们引入了组件自动扫描机制,他在类路径下寻找标注了上述注解的类,并把这些类纳入进spring容器中管理。
它的作用和在xml文件中使用bean节点配置组件时一样的。要使用自动扫描机制,我们需要打开以下配置信息:
代码
[html] view
plaincopy
<?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-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<context:component-scan base-package=”com.eric.spring”>
</beans>
1.component-scan标签默认情况下自动扫描指定路径下的包(含所有子包),将带有@Component、@Repository、@Service、@Controller标签的类自动注册到spring容器。对标记了 Spring's @Required、@Autowired、JSR250's @PostConstruct、@PreDestroy、@Resource、JAX-WS's @WebServiceRef、EJB3's @EJB、JPA's @PersistenceContext、@PersistenceUnit等注解的类进行对应的操作使注解生效(包含了annotation-config标签的作用)。
getBean的默认名称是类名(头字母小写),如果想自定义,可以@Service(“aaaaa”)这样来指定。
这种bean默认是“singleton”的,如果想改变,可以使用@Scope(“prototype”)来改变。
可以使用以下方式指定初始化方法和销毁方法:
[java] view
plaincopy
@PostConstruct
public void init() {
}
@PreDestroy
public void destory() {
}
注入方式:
把DAO实现类注入到action的service接口(注意不要是service的实现类)中,注入时不要new 这个注入的类,因为spring会自动注入,如果手动再new的话会出现错误,
然后属性加上@Autowired后不需要getter()和setter()方法,Spring也会自动注入。
在接口前面标上@Autowired注释使得接口可以被容器注入,如:
[java] view
plaincopy
@Autowired
@Qualifier("chinese")
private Man man;
当接口存在两个实现类的时候必须使用@Qualifier指定注入哪个实现类,否则可以省略,只写@Autowired。
相关文章推荐
- java.util.concurrent之CyclicBarrier
- java 和 maven 的环境变量设置
- Java JDBC批处理插入数据操作(转)
- struts配置中,页面跳转
- JAVA导出Excel(支持多sheet)
- Spring Data Jpa 详解
- 怎么快速 把一个 监听事件 变成 一个 内部类 在编程一个新的 java文件
- Java 二分查找的简单使用
- java.util.concurrent之CountDownLatch
- Java HTML导出PDF (二)
- Java数据持久层框架 MyBatis
- JAVA实现Excel批量导入
- Java HTML导出PDF (一)
- MyEclipse内存溢出问题解决方法
- java匿名内部类
- eclipse提交代码至GitHub
- JavaEE7+Websockets+GlassFish4打造聊天室
- 使用Eclipse Memory Analyzer进行内存泄漏分析三部曲
- java基本类型数组初始化
- Java中的单例模式的总结