Spring2.5、Struts2、Ibatis开发框架搭建(三)

Spring2.5、Struts2、Ibatis开发框架搭建(三)

三、整合Spring2.5,Struts2,iBATIS,DBCP,Log4j

3.1 what’s the point

       为什么要“整合”这些框架呢?在程序代码中由程序员负责处理与控制一切不是很好吗?要这么多的框架搭配在一起工作有什么好处呢?答案只有一个,“省事”,节省程序员开发程序的时间。

整合这些框架的关键一点就是SpringSpring是所有这些框架在一起工作的粘合剂,整合的工作重心就是将web MVC框架、ORM框架、数据库缓冲池框架、日志框架等全部交给Spring管理,由Spring调配使用这些框架综合在一起工作。

       3.2 Spring如何让Web项目加载?

              在第2.2小节中的配置参数中有一个listener是用来让我们的web项目在启动时就可以自动加载Spring框架及其参数配置文件的,即下面的这一行配置参数。

<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>

       </listener>

       3.3 Spring的参数配置文件如何被自动加载上?

              配置了Spring自动加载以后,在web项目的WEB-INF/web.xml中应该配置Spring参数文件的加载位置,即在2.2小节中需要配置的

   <!-- 应用程序上下文参数,指定spring配置文件位置 -->

       <context-param>

              <param-name>contextConfigLocation</param-name>

              <param-value>/WEB-INF/spring/applicationContext.xml  /WEB-INF/spring/ibatis_dao.xml /WEB-INF/spring/struts_action.xml</param-value>

       </context-param>

<param-value>后面配置Spring参数文件的路径,有多个Spring的参数配置文件存在时,各个参数文件之间用空格分隔开。

       3.4 如何让Spring管理Struts2

              要让Spring管理Struts2action bean的创建等工作,需要在项目的src目录中的struts.properties文件中指定

struts.objectFactory=spring

struts.objectFactory.spring.autoWire=type

       2.3 小节配置参数中包含的这两行。

       3.5 如何让Spring管理数据库缓冲池?

              DBCP或者C3p0等数据库缓冲池可以在Spring的参数配置文件当中去配置使用,例如在项目中配置DBCP数据库缓冲池的话可以指定以下格式的参数配置:

 

       <bean id="dataSource"

              class="org.apache.commons.dbcp.BasicDataSource"

              destroy-method="close">

              <property name="driverClassName"

                     value="${jdbc.driverClassName}" />

              <property name="url" value="${jdbc.url}" />

              <property name="username" value="${jdbc.username}" />

              <property name="password" value="${jdbc.password}" />

              <property name="initialSize" value="4" />

              <property name="maxActive" value="20" />

              <property name="testWhileIdle" value="true" />

              <property name="validationQuery"

                     value="select count(0) from t_db_history where 1=2" />

              <property name="testOnBorrow" value="true" />

       </bean>

       上面各个参数值中有的使用的是$符号加{}的形式进行配置的,这种配置格式需要在Spring当中配置一个能够加载.propertis文件的bean,如以下格式:

       <bean id="propertyConfigurer"

              class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

              <property name="locations">

                     <list>

                            <value>WEB-INF/jdbc.properties</value>

                     </list>

              </property>

       </bean>

       上面配置参数中的list元素后面跟随.properties文件列表。

当然,如果不想把参数文件写在Spring以外,也可以在配置DBCP的时候直接将连接数据库URL,用户,密码等等参数写死在Spring当中也是可以的。

       3.6 如果整合iBATIS框架?

              iBATIS框架要工作的话,需要指定一个全局的iBATIS参数配置文件,即在Spring中需要告诉iBATIS框架,你工作时需要使用的参数文件在哪里可以找到,另外,Spring框架对常见的ORM框架等等都进行了封装,所以要在Spring当中配置iBATIS框架的话,实际上要配置的类是Spring框架当中的某个类,如下:

 

       <bean id="sqlMapClient"

              class="org.springframework.orm.ibatis.SqlMapClientFactoryBean">

              <property name="configLocations"

                     value="WEB-INF/sql-map-config.xml" />

              <property name="dataSource" ref="dataSource" />

       </bean>

       上面的配置参数中的value="WEB-INF/sql-map-config.xml"即是用来告诉iBATIS框架它要使用的配置参数文件存放在哪个位置。

       以上配置参数中的property name="dataSource" ref="dataSource"即是用来告诉iBATIS框架,它要使用的数据源是在3.5小节中配置的数据库缓冲池。

       3.7 如何使用Spring 2.5 提供的AutoWired功能?

              Spring的参数配置文件中加入如下一行配置参数即可:

       <context:annotation-config />

       3.8 如何通过数据库的表自动生成实体类以及参数配置文件等等?

              需要使用iBATIS官方网站提供的iBATOR,在Eclipse当中可以安装该插件,Eclipse当中安装插件的方法这里不做描述。

              安装好iBATOR插件以后,用Eclipse的新建功能向项目中加入一个用于自动生成iBATIS实体类等的参数配置文件,在该文件当中指定本机上的JDBC数据驱动以及连接数据库的参数等等,配置好要生成的实体类,DAOSQL映射文件的存放路径,如果一切正常,配置完成以后即可自动根据数据库当中的表结构来产生实体类以及DAO等等。

       3.9 iBATOR生成的实体类以及DAO等如何应用?

              第一步需要先将生成的SQL映射文件添加到iBATIS的全局参数配置文件当中去,具体是哪一个文件是iBATIS框架的参数配置文件呢?3.6小节中的<property name="configLocations" value="WEB-INF/sql-map-config.xml" />这一行配置的是哪一个文件,那么那个文件就是iBATIS框架的全局配置参数文件。

       向里面加入某一个实体类对应的SQL映射文件的配置参数是如下格式:

       <sqlMap resource="edu/xw/ji/sqlmaps/t_db_history_SqlMap.xml" />

       3.10 Spring当中如何配置iBATOR自动生成的DAO类呢?

              iBATOR代码生成工具自动生成的DAO类的实现类有些特殊,即DAO实现类在实例化的时候需要传入一个构造参数,在3.6小节当中配置的那个类的数据类型就是这个构造函数要传入的参数数据类型,那么在Spring当中配置DAO实例时告诉它构造函数的参数是什么就可以了,如下:

       <bean id="sys_job_type_dao"

              class="edu.xw.ji.dao.SysJobTypeDAOImpl">

              <constructor-arg>

                     <ref bean="sqlMapClient" />

              </constructor-arg>

       </bean>

       3.11 Spring如何管理Struts2Action类?

              要让Struts2Action类与Spring一起工作,需要先在Spring当中定义bean,即将Struts2Action当成普通的bean定义在Spring当中,唯一需要注意的地方是要在Spring的配置参数当中加一句scope="prototype"

              然后在Struts2的参数配置文件中再去使用这个在Spring当中定义好的bean id就行了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值