【浅谈JavaEE框架32】Spring常用注解,自动扫描装配Bean

1.引入context命名空间(在Spring的配置文件中)

配置文件如下: 


Xml代码  
1.xmlns:context="http://www.springframework.org/schema/context"    
2.http://www.springframework.org/schema/context  
3.http://www.springframework.org/schema/context/spring-context-2.5.xsd   

打开配置 <context:component-scan base-package="包名(扫描本包及子包)"/> 

spring 会自动扫描cn.pic包下面有注解的类,完成Bean的装配。 

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-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="cn.pic"/>    
</beans>

2.在classPath中加入注解用的jar包 

lib\j2ee\common-annotations.jar
 
Spring 的context:component-scan扫描支持扫描jar包的方法:
 
eclipse自带的jar打包程序,默认打包的时候有个选项<Add directory entries>没有勾选,只要勾选了,就可以了.
 
-----------常用注解-------- 

--定义Bean的注解 

@Controller
 
@Controller("Bean的名称")
 
定义控制层Bean,如Action
 
 
@Service          
 
@Service("Bean的名称")
 
定义业务层Bean
 
 
@Repository   
 
@Repository("Bean的名称")
 
定义DAO层Bean
 
 
@Component  
 
定义Bean, 不好归类时使用.
 
 
--自动装配Bean (选用一种注解就可以)
 
@Autowired  (Srping提供的)
 
默认按类型匹配,自动装配(Srping提供的),可以写在成员属性上,或写在setter方法上
 
 
@Autowired(required=true)  
 
一定要找到匹配的Bean,否则抛异常。 默认值就是true 
 
 
@Autowired
 
@Qualifier("bean的名字") 
 
按名称装配Bean,与@Autowired组合使用,解决按类型匹配找到多个Bean问题。
 
 
@Resource   JSR-250提供的
 
默认按名称装配,当找不到名称匹配的bean再按类型装配.
 
可以写在成员属性上,或写在setter方法上
 
可以通过@Resource(name="beanName") 指定被注入的bean的名称, 要是未指定name属性, 默认使用成员属性的变量名,一般不用写name属性.
 
@Resource(name="beanName")指定了name属性,按名称注入但没找到bean, 就不会再按类型装配了.
 
 
@Inject   是JSR-330提供的
 
按类型装配,功能比@Autowired少,没有使用的必要。
 
 
--定义Bean的作用域和生命过程 

@Scope("prototype")
 
值有:singleton,prototype,session,request,session,globalSession
 
 
@PostConstruct 
 
相当于init-method,使用在方法上,当Bean初始化时执行。
 
 
@PreDestroy 
 
相当于destory-method,使用在方法上,当Bean销毁时执行。
 
 
--声明式事务 


@Transactional  
spring 事务注解

默认遇到throw new RuntimeException("...");会回滚
需要捕获的throw new Exception("...");不会回滚
 

// 指定回滚
@Transactional(rollbackFor=Exception.class) 
    public void methodName() {
       // 不会回滚
       throw new Exception("...");
    } 
//指定不回滚
@Transactional(noRollbackFor=Exception.class)
    public ItimDaoImpl getItemDaoImpl() {
        // 会回滚
        throw new RuntimeException("注释");
    } 
// 如果有事务,那么加入事务,没有的话新建一个(不写的情况下)
    @Transactional(propagation=Propagation.REQUIRED) 
    // 容器不为这个方法开启事务
    @Transactional(propagation=Propagation.NOT_SUPPORTED)
    // 不管是否存在事务,都创建一个新的事务,原来的挂起,新的执行完毕,继续执行老的事务
    @Transactional(propagation=Propagation.REQUIRES_NEW) 
    // 必须在一个已有的事务中执行,否则抛出异常
    @Transactional(propagation=Propagation.MANDATORY)
    // 必须在一个没有的事务中执行,否则抛出异常(与Propagation.MANDATORY相反)
    @Transactional(propagation=Propagation.NEVER) 
    // 如果其他bean调用这个方法,在其他bean中声明事务,那就用事务.如果其他bean没有声明事务,那就不用事务.
    @Transactional(propagation=Propagation.SUPPORTS) 
    /*
    public void methodName(){
       // 本类的修改方法 1
       update();
       // 调用其他类的修改方法
       otherBean.update();
       // 本类的修改方法 2
       update();
    }
    other失败了不会影响 本类的修改提交成功
    本类update的失败,other也失败
    */
@Transactional(propagation=Propagation.NESTED) 
// readOnly=true只读,不能更新,删除 
@Transactional (propagation = Propagation.REQUIRED,readOnly=true) 
// 设置超时时间
@Transactional (propagation = Propagation.REQUIRED,timeout=30)
// 设置数据库隔离级别
@Transactional (propagation = Propagation.REQUIRED,isolation=Isolation.DEFAULT)

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值