zoukankan      html  css  js  c++  java
  • Spring中常用的配置和注解详解

    一.  Spring中常用的配置文件详解

      

    Spring中的配置文件详解
        1.<!-- 配置注解bean的扫描路径 该配置表示从cn包下开始扫描-->
        <context:component-scan base-package="cn"></context:component-scan>
        
        2.<!-- 加载资源文件  其中Location表示从哪个路径加载配置文件properties-->
        <context:property-placeholder location="classpath:/cn/et/spring/day4/tx/jdbc.properties" />
        
        3.<!-- 获取数据源  其中properties表示数据库的连接四要素 -->
        <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
            <property name="url" value="${url}" />
            <property name="username" value="${userAccount}"></property>
            <property name="password" value="${password}"></property>
            <property name="driverClassName" value="${driverClass}"></property>
        </bean>
        
        4.<!-- 获取操纵数据库的类 jdbcTempLate-->
        <bean id="jdbcTempLate" class="org.springframework.jdbc.core.JdbcTemplate">
            <property name="dataSource" ref="dataSource"></property>
        </bean>
        
        5.<!-- 通过事物管理器来帮助我们管理事物 通常用于数据库的提交和回滚操作-->
        <bean id="transManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager" >
            <!-- 将连接注入到事物管理器内 通过事物管理器来管理 -->
            <property name="dataSource" ref="dataSource"></property>
        </bean>
        
        6.<!-- 在消息通知中注入 事物管理器 拦截到方法时调用事物管理器来管理事物 
            id:表示事物通知名称
            transaction-manager:表示事物管理器实例名称
        -->
        <tx:advice id="myAdvice" transaction-manager="transManager" >
            <tx:attributes>
                <!--method: 具体拦截的方法  -->
                <tx:method name="minusMoney" isolation="DEFAULT" propagation="REQUIRED" rollback-for="java.io.IOException" no-rollback-for="java.lang.ArrayIndexOutOfBoundsException"  />
                <tx:method name="addMoney" isolation="DEFAULT" propagation="REQUIRED" />
                
            </tx:attributes>
        </tx:advice>
        
        7.<!--使用AOP技术实现事物管理-->
        <aop:config>
            <!--其中id表示事物切入点名称,expression:表示事物切入点正则表达式,advice-ref:表示事物通知名称,pointcut-ref:表示事物切入点名称-->
            <aop:pointcut expression="execution(* cn.*..*.tx.*.*(..))" id="myPointCut"/>
            <aop:advisor advice-ref="myAdvice"  pointcut-ref="myPointCut"/>
        </aop:config>    

    二  . Spring中常用注解详解

       使用注解来构造Ioc容器

        用注解详Spring容器中注册Bean,需要在applationContext.xml中注册<context:component-scan base-package="cn"></context:component-scan>标签,如上标签表示扫描cn及其子包中带有特定的注解【@Component  /  @Repository   /  @Service   /  @Controller】  ,就会将这个对象作为Bean注册进Spring容器,也可以在该标签中指定多个包,如:

    <context:component-scan base-package="cn.gacl.dao.impl,cn.gacl.service.impl,cn.gacl.action"/>

    多个包之间用逗号隔开即可。

      1.@Component

        @Component是所有受Spring管理组件的通用形式,@Component注解可以防止类的头上,@Component不推荐使用。

      2.@Controller

        @Controller对应表现层的Bean,也就是Action.例如

    1 @Controller
    2 @Scope("prototype")
    3 public class UserAction extends BaseAction<User>{
    4 ……
    5 }

        使用@Controller注解标识UserAction之后,就表示要把UserAction交给Spring容器管理,在Spring容器中会存在一个名字为“userAction”的action,这个名字是根据UserAction类名来取的。注意:如果@Controller不指定value【@Controller】,则默认的bean名字是为这个类的类名首字母小写,如果指定value【@Controller(value="UserAction")】或者【@Controller(“UserAction”)】,则使用value作为bean的名字。

      

      3 . @Service

        @Service对应的是业务层Bean,例如:

    1 @Service("userService")
    2 public class UserServiceImpl implements UserService {
    3 ………
    4 }

        @Service(“userService”)注解是告诉Spring,当Spring要创建UserServiceImpl的实例是,bean的名字必须叫做“userService”,这样当Action需要使用UserServiceImpl的实例时,就可以由Spring创建好的“userService”,然后注入给Action 在Action只需要声明一个名字叫做“userService”的变量来接收由Spring注入的"userService"即可。具体代码如下:

    1 // 注入userService
    2 @Resource(name = "userService")
    3 private UserService userService;

        

        注意:在Action声明的“userService”变量的类型必须是“UserServiceImpl”或者是其父类“UserService”,否则由于类型不一致而无法注入,由于Action中的声明的“userService”变量使用了@Resource注解去标注,并且指明了其name = "userService",这就等于告诉Spring,说我Action要实例化一个“userService”,你Spring快点帮我实例化好,然后给我,当Spring看到userService变量上的@Resource的注解时,根据其指明的name属性可以知道,Action中需要用到一个UserServiceImpl的实例,此时Spring就会把自己创建好的名字叫做"userService"的UserServiceImpl的实例注入给Action中的“userService”变量,帮助Action完成userService的实例化,这样在Action中就不用通过“UserService userService = new UserServiceImpl();”这种最原始的方式去实例化userService了。如果没有Spring,那么当Action需要使用UserServiceImpl时,必须通过“UserService userService = new UserServiceImpl();”主动去创建实例对象,但使用了Spring之后,Action要使用UserServiceImpl时,就不用主动去创建UserServiceImpl的实例了,创建UserServiceImpl实例已经交给Spring来做了,Spring把创建好的UserServiceImpl实例给Action,Action拿到就可以直接用了。Action由原来的主动创建UserServiceImpl实例后就可以马上使用,变成了被动等待由Spring创建好UserServiceImpl实例之后再注入给Action,Action才能够使用。这说明Action对“UserServiceImpl”类的“控制权”已经被“反转”了,原来主动权在自己手上,自己要使用“UserServiceImpl”类的实例,自己主动去new一个出来马上就可以使用了,但现在自己不能主动去new“UserServiceImpl”类的实例,new“UserServiceImpl”类的实例的权力已经被Spring拿走了,只有Spring才能够new“UserServiceImpl”类的实例,而Action只能等Spring创建好“UserServiceImpl”类的实例后,再“恳求”Spring把创建好的“UserServiceImpl”类的实例给他,这样他才能够使用“UserServiceImpl”,这就是Spring核心思想“控制反转”,也叫“依赖注入”,“依赖注入”也很好理解,Action需要使用UserServiceImpl干活,那么就是对UserServiceImpl产生了依赖,Spring把Acion需要依赖的UserServiceImpl注入(也就是“给”)给Action,这就是所谓的“依赖注入”。对Action而言,Action依赖什么东西,就请求Spring注入给他,对Spring而言,Action需要什么,Spring就主动注入给他。

       4 . Repository

        @Repository对应数据库的访问层Bean,例如:

    1 @Repository(value="userDao")
    2 public class UserDaoImpl extends BaseDaoImpl<User> {
    3 ………
    4 }

        @Repository(value="userDao")注解是告诉Spring,让Spring创建一个名字叫“userDao”的UserDaoImpl实例。当Service需要使用Spring创建的名字叫“userDao”的UserDaoImpl实例是,就可以使用@Resource(name="userDao")注解告诉Spring,Spring把创建好的userDao注入个Service即可。

    1 // 注入userDao,从数据库中根据用户Id取出指定用户时需要用到
    2 @Resource(name = "userDao")
    3 private BaseDao<User> userDao;
  • 相关阅读:
    MTK 官方 openwrt SDK 使用
    PF_RING packet overwrites
    pycares cffi
    libevent evbuffer bug
    浮点转字符串性能比较
    重写 libev 的 EV_WIN32_HANDLE_TO_FD
    thrift TNonblockingServer 使用
    accel-pptp 部署
    boost::asio 使用 libcurl
    蜂鸟A20开发板刷 cubietruck 的 SD 卡固件
  • 原文地址:https://www.cnblogs.com/xushirong/p/7079536.html
Copyright © 2011-2022 走看看