mybatis3+spring3MVC

mybatis3+spring3MVC

 

 

最近,正在为公司搭建java部门的开发平台,记录下搭建的整个过程。

1.    环境介绍

1.1.   JDK

      jdk1.6.0_04

1.2.  Web服务器

      Tomcat6.0.29-windows-x86

1.3.   开发工具

Eclipse3.7 Version: Indigo Release    Build id: 20110615-0604

1.4.   使用的框架

后端:Mybatis(3.0.5) + Spring(3.0.5)MVC

前端:jQuery1.5.1

1.5.   数据库

MySQL(5.1)

2.    搭建过程

2.1.   项目结构

整个工程的编码是“utf-8”(包括里面所有的文件)。首先看一下整个项目的结构(里面涉及到公司名称的部分进行了处理):



 

接着,看看需要哪些jar包:



 

2.2.   配置文件

2.2.1 web.xml

Xml代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"  
  3.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.     xsi:schemaLocation="http://java.sun.com/xml/ns/javaee  
  5.     http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">  
  6.    
  7.     <!-- 载入spring上下文 -->  
  8.     <context-param>  
  9.        <param-name>contextConfigLocation</param-name>  
  10.        <param-value>/WEB-INF/applicationContext.xml</param-value>  
  11.     </context-param>  
  12.    
  13.     <!--  
  14.        载入springMVC配置  
  15.        如果<servlet-name>的名称为testMVC,则对应的xml文件则是testMVC-servlet.xml  
  16.     -->  
  17.     <servlet>  
  18.        <servlet-name>dispatcher</servlet-name>  
  19.        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
  20.        <init-param>  
  21.            <param-name>contextConfigLocation</param-name>  
  22.            <param-value>/WEB-INF/dispatcher-servlet.xml</param-value>  
  23.        </init-param>  
  24.        <load-on-startup>1</load-on-startup>  
  25.     </servlet>  
  26.     <servlet-mapping>  
  27.        <servlet-name>dispatcher</servlet-name>  
  28.        <url-pattern>*.do</url-pattern>  
  29.     </servlet-mapping>  
  30.    
  31.     <!-- Spring监听 -->  
  32.     <listener>  
  33.        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>  
  34.     </listener>  
  35.     <listener>  
  36.        <!-- Spring 刷新Introspector防止内存泄露 -->  
  37.         <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>  
  38.     </listener>  
  39.    
  40.     <!-- Spring过滤中文字符集 -->  
  41.     <filter>  
  42.        <filter-name>SetCharacterEncoding</filter-name>  
  43.        <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>  
  44.        <init-param>  
  45.            <param-name>encoding</param-name>  
  46.            <param-value>UTF-8</param-value>  
  47.        </init-param>  
  48.     </filter>  
  49.     <!-- 要过滤的类型 -->  
  50.     <filter-mapping>  
  51.        <filter-name>SetCharacterEncoding</filter-name>  
  52.        <url-pattern>/*</url-pattern>  
  53.     </filter-mapping>  
  54.    
  55.     <welcome-file-list>  
  56.        <welcome-file>index.jsp</welcome-file>  
  57.     </welcome-file-list>  
  58. </web-app>  
 

2.2.2  applicationContext.xml

Xml代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"   
  3.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    
  4.   xmlns:aop="http://www.springframework.org/schema/aop"   
  5.   xmlns:tx="http://www.springframework.org/schema/tx"    
  6.   xmlns:jdbc="http://www.springframework.org/schema/jdbc"   
  7.   xmlns:context="http://www.springframework.org/schema/context"  
  8.     xsi:schemaLocation="           
  9.       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd           
  10.       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd           
  11.       http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd           
  12.       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd           
  13.       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"  
  14.      >  
  15.        
  16.     <!-- jdbc属性文件读入 -->  
  17.     <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  18.         <property name="locations">  
  19.             <list>  
  20.                 <value>classpath:jdbc.properties</value>  
  21.             </list>  
  22.         </property>  
  23.     </bean>  
  24.        
  25.     <!-- 数据库连接池 -->  
  26.     <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close">  
  27.        <property name="driverClass" value="${jdbc.driver}" />  
  28.        <property name="jdbcUrl" value="${jdbc.url}" />  
  29.        <property name="user" value="${jdbc.username}" />  
  30.        <property name="password" value="${jdbc.password}" />  
  31.         
  32.         <!--连接池中保留的最小连接数。-->  
  33.     <property name="minPoolSize" value="5"/>  
  34.      
  35.     <!--连接池中保留的最大连接数。Default: 15 -->  
  36.     <property name="maxPoolSize" value="30"/>  
  37.      
  38.     <!--初始化时获取的连接数,取值应在minPoolSize与maxPoolSize之间。Default: 3 -->  
  39.     <property name="initialPoolSize" value="10"/>  
  40.      
  41.     <!--最大空闲时间,60秒内未使用则连接被丢弃。若为0则永不丢弃。Default: 0 -->  
  42.     <property name="maxIdleTime" value="10"/>  
  43.      
  44.     <!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。Default: 3 -->  
  45.     <property name="acquireIncrement" value="5"/>  
  46.      
  47.     <!--JDBC的标准参数,用以控制数据源内加载的PreparedStatements数量。  
  48.            但由于预缓存的statements属于单个connection而不是整个连接池。所以设  
  49.            置这个参数需要考虑到多方面的因素。如果maxStatements与maxStatementsPerConnection  
  50.            均为0,则缓存被关闭。Default: 0-->  
  51.     <property name="maxStatements" value="0"/>  
  52.      
  53.     <!--每60秒检查所有连接池中的空闲连接。Default: 0 -->  
  54.     <property name="idleConnectionTestPeriod" value="60"/>  
  55.      
  56.     <!--定义在从数据库获取新连接失败后重复尝试的次数。Default: 30 -->  
  57.     <property name="acquireRetryAttempts" value="30"/>  
  58.      
  59.     <!--获取连接失败将会引起所有等待连接池来获取连接的线程抛出异常。但是数据  
  60.            源仍有效保留,并在下次调用getConnection()的时候继续尝试获取连接。如果设  
  61.            为true,那么在尝试获取连接失败后该数据源将申明已断开并永久关闭。Default: false-->  
  62.     <property name="breakAfterAcquireFailure" value="true"/>  
  63.      
  64.     <!--因性能消耗大请只在需要的时候使用它。如果设为true那么在每个connection  
  65.            提交的时候都将校验其有效性。建议使用idleConnectionTestPeriod或automaticTestTable  
  66.            等方法来提升连接测试的性能。Default: false -->  
  67.     <property name="testConnectionOnCheckout" value="false"/>  
  68.     </bean>  
  69.      
  70.     <!-- Mybatis's sqlSessionFactory config -->  
  71.     <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  72.        <property name="dataSource" ref="dataSource"></property>  
  73.        <property name="configLocation" value="classpath:mybatis-config.xml"/>        
  74.     </bean>  
  75.      
  76.     <bean name="transactionManager"  
  77.        class="org.springframework.jdbc.datasource.DataSourceTransactionManager">  
  78.        <property name="dataSource" ref="dataSource"></property>  
  79.     </bean>  
  80.      
  81.     <!-- 启用事务 -->  
  82.     <tx:advice id="txAdvice" transaction-manager="transactionManager">  
  83.        <tx:attributes>  
  84.            <tx:method name="save*" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  85.       <tx:method name="create*" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  86.       <tx:method name="copy*" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  87.       <tx:method name="update*" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  88.       <tx:method name="delete*" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  89.       <tx:method name="find*" read-only="true" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  90.       <tx:method name="list*" read-only="true" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  91.       <tx:method name="is*" read-only="true" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  92.       <tx:method name="*" read-only="true" rollback-for="com.googosoft.framework.exception.CRUDException,Exception" />  
  93.        </tx:attributes>  
  94.     </tx:advice>  
  95.      
  96.     <!-- AOP代理设置 -->  
  97.     <aop:config>  
  98.     <aop:advisor pointcut="execution(* com.googosoft.framework.service.*.*(..))" advice-ref="txAdvice" />  
  99.     </aop:config>  
  100.    
  101.     <!—- 自动扫描 XXXMapper.java -->  
  102.     <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">        
  103.        <property name="basePackage" value="com.googosoft.framework.persistence" />  
  104.     </bean>  
  105.      
  106.   <!-- 激活annotation功能 -->  
  107.     <context:annotation-config />  
  108.      
  109.     <context:spring-configured/>  
  110.      
  111. </beans>  
 

 

其中,需要注意的2个地方是:

1.    jdbc.properties文件的位置:

Xml代码  收藏代码
  1. <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  2.        <property name="locations">  
  3.            <list>  
  4.                <value>classpath:jdbc.properties</value>  
  5.            </list>  
  6.        </property>  
  7. </bean>  
 

这里指的是classpath的位置,如果还有文件夹,可以写成“XXX / jdbc.properties”


2.    mybatis-config.xml文件的位置:

Xml代码  收藏代码
  1. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">  
  2.     <property name="dataSource" ref="dataSource"></property>  
  3.     <property name="configLocation" value="classpath:mybatis-config.xml"/>          
  4. </bean>  

 与jdbc需要注意的是一样的。

 

2.2.3 dispatcher-servlet.xml

Xml代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans xmlns="http://www.springframework.org/schema/beans"   
  3.   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  4.   xmlns:context="http://www.springframework.org/schema/context"  
  5.   xmlns:mvc="http://www.springframework.org/schema/mvc"  
  6.     xsi:schemaLocation="           
  7.       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd           
  8.       http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd  
  9.       http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd"  
  10.      >  
  11.    
  12.   <!-- 扫描指定package下所有带有如@controller,@services,@resource,并把所注释的注册为Spring Beans -->  
  13.     <context:component-scan base-package="com.googosoft">  
  14.     <context:include-filter type="regex" expression="com.googosoft.framework.service.*"/>  
  15.     <context:include-filter type="regex" expression="com.googosoft.framework.web.*"/>  
  16.   </context:component-scan>  
  17.    
  18.    
  19.   <!-- 只能用于springMVC,用于配置springMVC的注解驱动 -->   
  20.   <mvc:annotation-driven />   
  21.    
  22.   <!-- Spring mvc视图解析器  -->                        
  23.   <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">   
  24.       <property name="prefix" value="/view/" />   
  25.       <property name="suffix" value=".jsp" />   
  26.   </bean>    
  27.      
  28. </beans>  
 

2.2.4 mybatis-config.xml

Xml代码  收藏代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">  
  3.    
  4.    
  5. <configuration>  
  6.    
  7.     <!-- 运行时,参数信息 -->  
  8.     <settings>  
  9.      
  10.        <!-- 使全局的映射器启用或禁用缓存。 -->  
  11.        <setting name="cacheEnabled" value="true"/>  
  12.         
  13.        <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载。 -->  
  14.        <setting name="lazyLoadingEnabled" value="true"/>  
  15.         
  16.        <!-- 当启用时,有延迟加载属性的对象在被调用时将会完全加载任意属性。否则,每种属性将会按需要加载。 -->  
  17.        <setting name="aggressiveLazyLoading" value="true"/>  
  18.         
  19.        <!-- 允许或不允许多种结果集从一个单独的语句中返回(需要适合的驱动)。 -->  
  20.        <setting name="multipleResultSetsEnabled" value="true"/>  
  21.         
  22.        <!-- 使用列标签代替列名。 -->  
  23.        <setting name="useColumnLabel" value="true"/>  
  24.         
  25.        <!-- 允许JDBC支持生成的键。 -->  
  26.        <setting name="useGeneratedKeys" value="false"/>  
  27.         
  28.        <!-- 指定MyBatis如何自动映射列到字段/属性。 -->  
  29.        <setting name="autoMappingBehavior" value="PARTIAL"/>  
  30.         
  31.        <!-- 配置默认的执行器。 -->  
  32.        <setting name="defaultExecutorType" value="SIMPLE"/>  
  33.     </settings>  
  34.      
  35.     <!-- java类别名 -->  
  36.     <typeAliases>  
  37.        <typeAlias alias="User" type="com.googosoft.framework.domain.system.User" />  
  38.        <typeAlias alias="Department" type="com.googosoft.framework.domain.system.Department" />  
  39.     </typeAliases>  
  40.      
  41.     <!-- SQL映射语句 -->  
  42.     <mappers>  
  43.        <mapper resource="mapper/system/UserMapper.xml"/>  
  44.        <mapper resource="mapper/system/DepartmentMapper.xml"/>  
  45.     </mappers>  
  46.      
  47. </configuration>  
 

2.2.5 jdbc.properties

Java代码  收藏代码
  1. jdbc.driver=com.mysql.jdbc.Driver  
  2. jdbc.url=jdbc:mysql://127.0.0.1:3306/gframe?useUnicode=true&characterEncoding=UTF-8  
  3. jdbc.username=root  
  4. jdbc.password=root  
 

2.2.6 log4j.properties

Java代码  收藏代码
  1. log4j.rootLogger=INFO,stdout,docout  
  2.    
  3. ### print Mybatis logging  
  4. log4j.logger.org.apache.ibatis=DEBUG  
  5. log4j.logger.java.sql=DEBUG  
  6.    
  7. log4j.appender.stdout=org.apache.log4j.ConsoleAppender  
  8. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout  
  9. log4j.appender.stdout.layout.ConversionPattern=-----------------------------------------------------------------------------------%nLevel\:[%p]%nTime\:[%d]%nClass\:[%l]%nMessage\:[%m]%n  
  10.    
  11. log4j.appender.docout=org.apache.log4j.DailyRollingFileAppender  
  12. log4j.appender.docout.File=log/log.html  
  13. log4j.appender.docout.Append=true  
  14. log4j.appender.docout.DatePattern=yyyy-MM-dd'.html'  
  15. log4j.appender.docout.layout=org.apache.log4j.HTMLLayout  
 
posted on 2011-09-21 10:43  sin  阅读(360)  评论(0编辑  收藏  举报

阳江人才网