Spring 学习笔记6—— 注解开发

1 修改配置文件

applicationContext.xml

增加命名空间的和约束文件

<beans ...

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

2.开启Spring的注解功能

<!-- 扫描注解类  
    base-package : 表示当前扫描的包,框架会根据包查找所有使用注解的类  
 -->  
<context:component-scan base-package="com.xundh.test.spring.*" />  

这里可能会遇到代码有提示:

advised by org.springframework.transaction.interceptor.TransactionIntercepto

这里写图片描述
提示spring事务管理异常,处理方法是:

<context:component-scan base-package="com.cn.test.services" use-default-filters="false"/>

参考:http://www.oschina.net/question/2272241_2146828?sort=time
然而直接加可能又会遇到hibernate失效的问题。
原因:
1. <context:component-scan>会交给org.springframework.context.config.ContextNamespaceHandler处理:

registerBeanDefinitionParser("component-scan", new ComponentScanBeanDefinitionParser());

2. <context:component-scan>的use-default-filters默认true,会交给ClassPathScanningCandidateComponentProvider进行扫描,

protected void registerDefaultFilters() {
 this.includeFilters.add(new AnnotationTypeFilter(Component.class));
 ClassLoader cl = ClassPathScanningCandidateComponentProvider.class.getClassLoader();
 try {
     this.includeFilters.add(new AnnotationTypeFilter(
             ((Class<? extends Annotation>) cl.loadClass("javax.annotation.ManagedBean")), false));
     logger.debug("JSR-250 'javax.annotation.ManagedBean' found and supported for component scanning");
 }
 catch (ClassNotFoundException ex) {
     // JSR-250 1.1 API (as included in Java EE 6) not available - simply skip.
 }
 try {
     this.includeFilters.add(new AnnotationTypeFilter(
             ((Class<? extends Annotation>) cl.loadClass("javax.inject.Named")), false));
     logger.debug("JSR-330 'javax.inject.Named' annotation found and supported for component scanning");
 }
 catch (ClassNotFoundException ex) {
     // JSR-330 API not available - simply skip.
 }
}

可以看到默认ClassPathBeanDefinitionScanner会自动注册对@Component、@ManagedBean、@Named注解的Bean进行扫描。如果细心,到此就找到问题根源了。
3. 对exclude-filter,include-filter进行过滤
首先通过exclude-filter 进行黑名单过滤;
然后通过include-filter 进行白名单过滤;
否则默认排除。

所以,<context:component-scan这段代码不仅仅对@Controller的注解Bean进行了扫描,而且对@Comonent注解也扫描了,子注解@Service,@Repository也进行了扫描,所以原来mvc的上下文的Bean被后面的bean替换了。所以如下解决方法:

  1. 如果不需要默认的,则use-default-filters=“false”禁用掉。
  2. 直接写明具体Controller包名称。

示例:

    <context:component-scan base-package="com.cn.test.services" use-default-filters="false">
         <context:include-filter type="annotation" expression="org.springframework.stereotype.Repository"/>  
         <context:include-filter type="annotation" expression="org.springframework.stereotype.Component" />
         <context:include-filter type="annotation" expression="org.springframework.transaction.annotation.Transactional" />
         <context:include-filter type="annotation" expression="javax.ws.rs.ext.Provider" />
    </context:component-scan>

参考:
http://blog.csdn.net/u014520797/article/details/50667720

3.声明注解类

类的分层注解

Spring框架提供了三种对于不同层的注解方式:
- 控制层:@Controller
- 服务层:@Service
- 持久层:@Repository

类似于配置文件中的:

<bean id="orgService" class="com.xundh.web.Service.TestService"></bean>

默认情况下使用注解声明的Bean对象id名称为:类名称的首字母小写,
一般不需要我们进行设置,如果想要设置时,如我们指定的实现类,而名字指向了接口,直接添加value属性即可:
@Service(value=”name”)。 value也是可以省略的。

Spring框架还为我们提供了代替 边三个分层注解的通用注解:@Component。

自动装配功能的实现对象之间的组合关系
  • @Autowired : 采用类型的方式完成自动装配 : byType
  • @Resource : 采用名称+类型的方式完成自动装配 : byName +byType,此种方法推荐使用。
    另外Spring提供的两种注解的自动装配功能,属性不需要声明set,get方法也可以完成组合功能,这是非常方便的。
在声明action时,需要指定其为多例的,解决线程安全的问题,在配置文件中我们通常会这样声明action的类
<bean id="orgAction" class="com.ljh.web.action.OrgAction" scope="prototype"></bean> 

而在Spring注解开发中也提供了类似的属性来解决此问题,在action类前边设定如下:

@Scope("prototype")
利用配置文件声明Dao层类时,通常是这样的
<!-- dao层需要引用我们的sessionFactory工厂,自动装配时,  
        是会自动装配名叫sessionFactory的工厂,所以可以省略。   
    -->  
    <bean name ="orgTypeDao" class="com.ljh.dao.impl.OrgTypeDaoImpl">  
        <!--<property name="sessionFactory" ref="sessionFactory"></property>-->  
    </bean>  

注解开发的方法如何进行sessionFactory注入:
Dao层从HibernateDaoSupport继承,父类有一个

//父类中的sessionFactory的set注入方法  
public ublic final void setSessionFactory(SessionFactory sessionFactory) {  
if (this.hibernateTemplate == null || sessionFactory != this.hibernateTemplate.getSessionFactory()) {  
    this.hibernateTemplate = createHibernateTemplate(sessionFactory);  
}  

方法,这是sessionFactroy的set注入应运。如果重写此方法,在此方法上进行@Resource注解,即可解决我们的问题,但是可以看到此方法是用final修饰的,所以通常情况下,使用下边这种方法进行解决:

@Repository("orgDao")  
public class OrgDaoImpl extends HibernateDaoSupport implements OrgDao {  

    @Resource  
    //自定义了方法,解决了父类中final修饰不能重写的问题  
    public void setSuperSessionFactory(SessionFactory sessionFactory) {  
             //调用了父类的setSessionFactory方法  
        super.setSessionFactory(sessionFactory);  
    }  
}  

这样,Dao层的sessionFactory就进行了注入,我们可以正常编写我们的Dao层代码了。

转载自:
http://blog.csdn.net/liujiahan629629/article/details/22696031

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring是一个开源的Java框架,用于构建企业级应用程序。它提供了一种轻量级的、非侵入式的开发方式,通过依赖注入和面向切面编程等特性,简化了Java应用程序的开发过程。 以下是关于Spring学习的一些笔记: 1. IoC(控制反转):Spring通过IoC容器管理对象的创建和依赖关系的注入。通过配置文件或注解,将对象的创建和依赖关系的维护交给Spring容器来管理,降低了组件之间的耦合度。 2. DI(依赖注入):Spring通过依赖注入将对象之间的依赖关系解耦。通过构造函数、Setter方法或注解,将依赖的对象注入到目标对象中,使得对象之间的关系更加灵活和可维护。 3. AOP(面向切面编程):Spring提供了AOP的支持,可以将与业务逻辑无关的横切关注点(如日志、事务管理等)从业务逻辑中分离出来,提高了代码的可重用性和可维护性。 4. MVC(模型-视图-控制器):Spring提供了一个MVC框架,用于构建Web应用程序。通过DispatcherServlet、Controller、ViewResolver等组件,实现了请求的分发和处理,将业务逻辑和视图展示进行了分离。 5. JDBC和ORM支持:Spring提供了对JDBC和ORM框架(如Hibernate、MyBatis)的集成支持,简化了数据库访问的操作,提高了开发效率。 6. 事务管理:Spring提供了对事务的支持,通过声明式事务管理和编程式事务管理,实现了对数据库事务的控制和管理。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值