zoukankan      html  css  js  c++  java
  • MyBatis-Spring-SpringMVC整合

    整合项目地址:https://github.com/mybatis/spring

    一. 依赖包:

       》1.SpringMVC依赖包:

    <!-- SpringMVC-核心 -->
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>5.1.7.RELEASE</version>
    </dependency>
    <!-- SpringMVC-文件上传 -->
    <dependency>
      <groupId>commons-fileupload</groupId>
      <artifactId>commons-fileupload</artifactId>
      <version>1.4</version>
    </dependency>
    <dependency>
      <groupId>commons-io</groupId>
      <artifactId>commons-io</artifactId>
      <version>2.6</version>
    </dependency>
    <!-- SpringMVC-Restful -->
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.9.9</version>
    </dependency>
    <dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-core</artifactId>
      <version>2.9.9</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-annotations</artifactId>
      <version>2.9.9</version>
    </dependency>
    <!-- servlet-jsp -->
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>javax.servlet-api</artifactId>
      <version>4.0.1</version>
      <scope>provided</scope>
    </dependency>
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
     </dependency>
    <build>
    <resources>
    <resource>
    <directory>src/main/java</directory>
    <includes>
    <include>**/*.xml</include>
    </includes>
    </resource>
    </resources>
    </build>

      》2.Spring依赖包:

    <!-- Spring-IOC-->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-core</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-beans</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-context-support</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <!-- String-AOP -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aop</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-aspects</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <!-- spring-jdbc -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-jdbc</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-tx</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-orm</artifactId>
        <version>5.1.7.RELEASE</version>
    </dependency>
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
    <dependency>
        <groupId>com.mchange</groupId>
        <artifactId>c3p0</artifactId>
        <version>0.9.5.4</version>
    </dependency>
    <!-- log4j是具体的日志系统:通过slf4j-log4j12初始化Log4j,达到最终日志的输出 -->
    <dependency>
        <groupId>org.apache.logging.log4j</groupId>
        <artifactId>log4j-core</artifactId>
        <version>2.11.2</version>
    </dependency>
    
    <!-- 测试 -->
    <dependency>
        <groupId>org.springframework</groupId>
        <artifactId>spring-test</artifactId>
        <version>5.1.7.RELEASE</version>
        <scope>test</scope>
    </dependency>
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>4.12</version>
        <scope>test</scope>
    </dependency>

      》3.MyBatis依赖包:

    <!-- MyBatis -->
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis</artifactId>
        <version>3.5.1</version>
    </dependency>
    <dependency>
        <groupId>org.mybatis</groupId>
        <artifactId>mybatis-spring</artifactId>
        <version>2.0.1</version>
    </dependency>

    二、配置文件:创建Spring、SpringMVC、MyBatis的配置文件

      》1.创建MyBatis的配置文件(mybatis-config.xml)以及映射文件(mapper):

     mapper.xml:

    <?xml version="1.0" encoding="UTF-8"?>
    <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    
    <mapper namespace="cn.ll.dao.EmployeeMapper">
      <resultMap id="BaseResultMap" type="Employee">
        <id column="eid" jdbcType="BIGINT" property="eid" />
        <result column="name" jdbcType="VARCHAR" property="name" />
        <result column="gender" jdbcType="VARCHAR" property="gender" />
        <result column="email" jdbcType="VARCHAR" property="email" />
      </resultMap>
      <select id="selectAll" resultMap="BaseResultMap">
        select eid, name, gender, email
        from employee
      </select>
    </mapper>

    mybatis-config.xml:

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
            PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-config.dtd">
    
    <configuration>
    </configuration>

      》2.Spring的配置文件:(applicationContext.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"
           xmlns:mvn="http://www.springframework.org/schema/mvc"
           xmlns:aop="http://www.springframework.org/schema/aop"
           xmlns:tx="http://www.springframework.org/schema/tx" xmlns:mvc="http://www.springframework.org/schema/mvc"
           xmlns:mybatis-spring="http://mybatis.org/schema/mybatis-spring"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           https://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/mvc
           https://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/aop https://www.springframework.org/schema/aop/spring-aop.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://mybatis.org/schema/mybatis-spring http://mybatis.org/schema/mybatis-spring.xsd">
    
        <!-- 包扫描 -->
        <context:component-scan base-package="cn.ll.action,cn.ll.dao,cn.ll.service"/>
        <!-- 加载数据库资连接信息资源文件 -->
        <context:property-placeholder location="classpath:database.properties"/>
        <!-- 启用Annotation注解 -->
        <aop:aspectj-autoproxy />
        <!-- 数据库连接池 -->
        <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
            <property name="driverClass" value="${datasource.driver}"/>
            <property name="jdbcUrl" value="${datasource.url}"/>
            <property name="user" value="${datasource.username}"/>
            <property name="password" value="${datasource.password}"/>
            <property name="maxPoolSize" value="${datasource.maxPoolSize}"/> <!-- 最大连接数 -->
            <property name="initialPoolSize" value="${datasource.initialPoolSize}"/> <!-- 初始化连接数 -->
            <property name="minPoolSize" value="${datasource.minPoolSize}"/> <!-- 最小维持连接数 -->
            <property name="maxIdleTime" value="${datasource.maxIdleTime}"/>  <!-- 最大等待时间,毫秒 -->
        </bean>
        <!-- 注入JdbcTemplate -->
        <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
            <property name="dataSource" ref="dataSource"/>
        </bean>
    
        <!-- 事务-配置事务管理器-->
        <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource"/>
        </bean>
        <!-- 事务-此时进行了AOP之中的切面关注点的操作配置,主要针对于事务管理生效 -->
        <tx:advice id="txAdvice" transaction-manager="transactionManager">
            <tx:attributes> <!-- 定义要匹配的操作业务方法 -->
                <tx:method name="add*" propagation="REQUIRED"/>
                <tx:method name="create*" propagation="REQUIRED"/>
                <tx:method name="remove*" propagation="REQUIRED"/>
                <tx:method name="delete*" propagation="REQUIRED"/>
                <tx:method name="edit*" propagation="REQUIRED"/>
                <tx:method name="update*" propagation="REQUIRED"/>
                <tx:method name="login*" propagation="REQUIRED"/>
                <tx:method name="list*" propagation="REQUIRED" read-only="true"/>
                <tx:method name="get*" propagation="REQUIRED" read-only="true"/>
            </tx:attributes>
        </tx:advice>
        <!-- 事务-设置好事务的关注点之后,下面就需要考虑设置一个事务的横切表达式,找到业务层匹配 -->
        <aop:config>
            <aop:pointcut id="servicePointcut" expression="execution(* cn.ll.service.*.*(..))"/>
            <aop:advisor advice-ref="txAdvice" pointcut-ref="servicePointcut"/>    <!-- 事务控制切入点 -->
        </aop:config>
    
        <!-- 整合MyBatis
            1.Spring管理所有组件,mapper的实现类;service调用Dao时,实现@Autowired:自动注入
            2.通过Spring管理实务
         -->
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean" >
            <!-- 数据源 -->
            <property name="dataSource" ref="dataSource" />
            <!-- 指定MyBatis的全部配置文件 -->
            <property name="configLocation" value="classpath:mybatis/mybatis-config.xml" />
            <!-- 当mapper接口和mapper.xml映射文件不在在一个包时,可以使用此配置,指定Mapper.xml文件位置 -->
            <!--<property name="mapperLocations" value="classpath:mybatis/mapper/*.xml"/>-->
            <!-- 批量别名 -->
            <property name="typeAliasesPackage" value="com.ll.admin.vo" />
        </bean>
        <!-- 当mapper接口和mapper.xml映射文件在一个包时,可以使用此配置,
            扫描所有的mapper接口,让这些mapper能够自动注入,base-package:指定mapper接口的包名 -->
        <mybatis-spring:scan base-package="com.ll.admin.dao"  />
        <!-- 当mapper接口和mapper.xml映射文件不在在一个包时,可以使用此配置,
            追加一个映射配置转换的处理工具类 -->
        <!--<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="com.yootk.ssm.dao"/>    &lt;!&ndash; DAO接口所在包名称 &ndash;&gt;
            <property name="sqlSessionFactoryBeanName" value="sessionFactory"/> &lt;!&ndash; SessionFactory-Bean名称 &ndash;&gt;
        </bean>-->
    </beans>

      》3.SpringMVC的配置文件:(spring-mvc.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"
           xmlns:mvn="http://www.springframework.org/schema/mvc"
           xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/context
           https://www.springframework.org/schema/context/spring-context.xsd
           http://www.springframework.org/schema/mvc
           https://www.springframework.org/schema/mvc/spring-mvc.xsd">
        <!-- 包扫描 -->
        <context:component-scan base-package="cn.ll.action" />
        <!-- 启用控制层注解 -->
        <mvn:annotation-driven />
        <!--使用Dispatcher处理请求-->
        <mvn:default-servlet-handler />
        <!-- 定义页面资源解析处理类,匹配路径的前缀与后缀-->
        <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="prefix" value="/WEB-INF/pages/" />
            <property name="suffix" value=".jsp" />
        </bean>
        <!-- 为保存在WEB-INF静态资源设置映射访问路径-->
        <mvn:resources mapping="/js/**" location="/WEB-INF/js/" />
        <mvn:resources mapping="/css/**" location="/WEB-INF/css/" />
        <mvn:resources mapping="/images/**" location="/WEB-INF/images/" />
        <!-- 进行要加载的"*.properties"配置文件路径加载,直接通过CLASSPATH加载 -->
        <bean class="org.springframework.context.support.ResourceBundleMessageSource">
            <property name="basenames">
                <array>
                    <value>cn.ll.redis.message.pages</value>
                    <value>cn.ll.redis.message.message</value>
                </array>
            </property>
        </bean>
        <!-- 配置上传文件解析处理类 -->
        <bean class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
            <!-- 设置整体上传文件的最大数据量,本次允许上传最大文件量为5M -->
            <property name="maxUploadSize" value="5242880"/>
            <!-- 设置单个上传文件的最大数据量,本次允许上传最大文件量为2M -->
            <property name="maxUploadSizePerFile" value="253952"/>
            <!-- 允许占用的最大内存量,本次设置为10M -->
            <property name="maxInMemorySize" value="10485760"/>
            <!-- 设置上传文件的临时保存目录,该目录的内容在每一次请求之后都需要清空 -->
            <property name="uploadTempDir" value="/tmp"/>
        </bean>
        <!-- 配置全局跳转页面 -->
        <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver" >
            <property name="exceptionMappings"><!-- 异常映射 -->
                <props>
                    <prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">plugins/errors</prop>
                </props>
            </property>
        </bean>
    </beans>

      》4.在web.xml中启动Spring和SpringMVC:

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
             xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
             http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
             version="4.0">
        <!-- WEB容器启动的时候实现Spring容器的启动 -->
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/application.xml</param-value>
        </context-param>
        <listener>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>
        <!-- SpringMVC的启动 -->
        <servlet>
            <servlet-name>dispatcherServlet</servlet-name>
            <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
            <init-param>
                <param-name>contextConfigLocation</param-name>
                <param-value>classpath:spring/spring-mvc.xml</param-value>
            </init-param>
            <load-on-startup>1</load-on-startup>
        </servlet>
        <servlet-mapping>
            <servlet-name>dispatcherServlet</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
        <!-- 编码过滤器 -->
        <filter>
            <filter-name>characterEncodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
            <init-param>
                <param-name>encoding</param-name>
                <param-value>UTF-8</param-value>
            </init-param>
            <init-param>
                <param-name>forceEncoding</param-name>
                <param-value>true</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>characterEncodingFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>
    </web-app>

     三、资源文件:

      数据库连接信息:database.properties

    datasource.driver=org.gjt.mm.mysql.Driver
    datasource.url=jdbc:mysql://localhost:3306/mybatis
    datasource.username=root
    datasource.password=123456
    datasource.maxPoolSize=1
    datasource.initialPoolSize=1
    datasource.minPoolSize=1
    datasource.maxIdleTime=1000

      日志文件:log4j.properties、lo4j2.xml

  • 相关阅读:
    分布式数据库拆分表常用的方法
    linux服务器502错误详解【转载】
    全国各城市代码
    Linux下git安装
    linux上访问windows目录
    百度技术总监谈12306高性能海量并发网站架构设计
    Ubuntu 10.04 安装无线网卡驱动。
    晕菜, silverlight !
    linux 软件记录.
    硬盘安装 Ubuntu10.04
  • 原文地址:https://www.cnblogs.com/luliang888/p/11080580.html
Copyright © 2011-2022 走看看