您的位置:首页 > 编程语言 > Java开发

mybatis3+springmvc4+spring4整合教程

2016-08-27 16:50 399 查看

一、包的准备

springmvc4

spring4

mybatis

c3p0

mybatis-spring-1.3.0(版本要1.3以上)

commons-logging(公共日志包)

mysql-connector-java(mysql连接驱动包)

二、包的导入

导入包的目录:



spring4+springmvc4:

spring-framework-4.3.1.RELEASE\libs目录下有很多包,但不需要每个都导入,这里只需要导入以下包:

spring-aop-4.3.1.RELEASE.jar

spring-beans-4.3.1.RELEASE.jar

spring-context-4.3.1.RELEASE.jar

spring-context-support-4.3.1.RELEASE.jar

spring-core-4.3.1.RELEASE.jar

spring-jdbc-4.3.1.RELEASE.jar

spring-orm-4.3.1.RELEASE.jar

spring-tx-4.3.1.RELEASE.jar

spring-web-4.3.1.RELEASE.jar

spring-expression-4.3.1.RELEASE.jar

spring-webmvc-4.3.1.RELEASE.jar

c3p0:

将以下两个包导入

c3p0-0.9.2.1.jar

mchange-commons-java-0.2.3.4.jar

commons-logging、mysql-connector-java、mybatis-spring-1.3.0(版本要1.3以上):

找到包全部导入即可

三、文件配置

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
<display-name>springMVC4_spring4_hiberante4</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
<!-- spring加载的配置文件路径 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:spring.xml</param-value>
</context-param>
<!-- 配置spring -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 配置springmvc -->
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- springmvc加载配置文件路径 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<!-- springmvc映射路径 -->
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>

<!-- 编码过滤器 -->
<filter>
<filter-name>CharacterEncoding</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>
</filter>
<!-- 编码过滤器映射路径 -->
<filter-mapping>
<filter-name>CharacterEncoding</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>

</web-app>


spring.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:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation=" http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
">

<!-- 引入配置文件 -->
<context:property-override location="classpath:dbcon.properties" />

<!-- 配置数据源 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
</bean>

<!-- spring和MyBatis完美整合 mapperLocations加载mybatis的映射文件。 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations" value="classpath:ssm/dao/*.xml" />
</bean>

<!-- DAO接口所在包名,Spring会自动查找其下的类 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="ssm.dao"></property>
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
</bean>

<!-- 事务管理 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>

<!-- 声明事务 -->
<tx:annotation-driven transaction-manager="transactionManager" />
</beans>


springmvc.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:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="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 http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd" >

<!-- 处理请求时返回json字符串的中文乱码问题 -->
<mvc:annotation-driven>
<mvc:message-converters>
<bean class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>application/json;charset=UTF-8</value>
</list>
</property>
</bean>
</mvc:message-c
4000
onverters>
</mvc:annotation-driven>

<!-- 开启controller注解支持 -->
<context:component-scan base-package="ssm.controller" >
</context:component-scan>

<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/jsp/"/>
<property name="suffix" value=".jsp"/>
</bean>

</beans>


dbcon.properties

dataSource.driverClass=com.mysql.jdbc.Driver
dataSource.jdbcUrl=jdbc:mysql:///ssh?useUnicode=true&characterEncoding=UTF-8
dataSource.user=root
dataSource.password=root
dataSource.initialPoolSize=2
dataSource.minPoolSize=2
dataSource.maxPoolSize=15
dataSource.maxIdleTime=30


UserDaoMapper.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" >

<!-- namespace命名空间,作用就是对sql进行分类化的管理,理解为sql隔离
注意:使用mapper代理开发时,namespace有特殊作用,namespace等于mapper接口地址
-->
<mapper namespace="ssm.dao.StudentDao" >

<!-- id名字要与接口的方法名相同 -->
<select id="get" parameterType="int" resultType="ssm.entity.Student">
select * from t_student where id = #{id}
</select>

<insert id="save" parameterType="ssm.entity.Student" >
insert  into t_student(name, age , sex) values(#{name},#{age},#{sex})
</insert>

</mapper>


以上是主要的配置文件,源码和测试用例地址:

https://yunpan.cn/cMRdY9sRxx5AX (提取码:7a66)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: