1、创建web工程,并导入相应的jar包
(1)、spring相关jar包,包括springmvc相关jar包
(2)、mybatis相关jar包
(3)、mybatis-spring整合包
(4)、数据库驱动包
(5)、数据库连接池包
2、整合思路
1、dao层
(1)、sqlMapConfig.xml 只需要有文件头的空文件即可
(2)、applicationContext-dao.xml
(a)、读取properties文件
(b)、配置数据源
(c)、配置sqlSessionFactory,mybatis-spring整合包下的类
(d)、配置mapper扫描器。
2、service层
(1)、applicationContext-service.xml 配置扫描器
(2)、applicationContext-trans.xml 配置事务,(事务管理器、通知、切面)
3、controller层
(1)、springmvc.xml
(a)、配置包扫描器
(b)、配置注解驱动
(c)、配置试图解析器
(2)、web.xml
(a)、配置spring 上下文位置
(b)、配置spring监听器
(c)、配置过滤器解决post乱码
(d)、配置前段控制器
3、项目结构
4、配置文件
1、applicationContext-dao.xml
<!-- 配置 读取properties文件 --> <context:property-override location="classpath:jdbc.properties"/> <!-- 配置数据源 --> <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"> <!-- 驱动 --> <property name="driverClassName" value="${jdbc.driver}"/> <!-- url --> <property name="url" value="${jdbc.url}"/> <!-- 用户名 --> <property name="username" value="${jdbc.username}"/> <!-- 密码 --> <property name="password" value="${jdbc.password}"/> </bean> <!-- 配置sqlSessionFactory --> <bean class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 数据源 --> <property name="dataSource" ref="dataSource"/> <!-- 配置Mybatis核心 即配置文件所在的地方 --> <property name="configLoction" value="classpath:sqlMapConfig.xml"/> <!-- 配置实体类的别名 --> <!-- <property name="typeAliasesPackage" value="com.ssm.core.pojo"/> --> </bean> <!-- 配置Mapper扫描 --> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 设置Mapper扫描包 --> <property name="basePackage" value="com.ssm.core.dao"/> </bean> |
2、applicationContext-service.xml
<!-- 配置扫描器 --> <context:component-scan base-package="com.ssm.core.service"/> |
3、applicationContext-trans
<!-- 事务管理器 --> <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <!-- 配置数据源 --> <property name="dataSource" ref="dataSource"/> </bean> <!-- 通知 --> <tx:advice id="txAdvice" transaction-manager="transactionManager"> <tx:attributes> <!-- 传播行为 --> <tx:method name="save*" propagation="REQUIRED"/> <tx:method name="insert*" propagation="REQUIRED" /> <tx:method name="add*" propagation="REQUIRED" /> <tx:method name="create*" propagation="REQUIRED" /> <tx:method name="delete*" propagation="REQUIRED" /> <tx:method name="update*" propagation="REQUIRED" /> <tx:method name="find*" propagation="SUPPORTS" read-only="true" /> <tx:method name="select*" propagation="SUPPORTS" read-only="true" /> <tx:method name="get*" propagation="SUPPORTS" read-only="true" /> </tx:attributes> </tx:advice> <!-- 切面 --> <aop:config> <aop:advisor advice-ref="txAdvice" pointcut="execution(* com.ssm.core.service.*.*(..))"/> </aop:config> |
4、sqlMapConfig.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> |
5、springmvc.xml
<!-- 配置扫描器 --> <context:component-scan base-package="com.ssm.core.controller"></context:component-scan> <!-- 配置注解驱动 : 相当于处理器映射器、适配器--> <mvc:annotation-driven/> <!-- 配置视图解析器 --> <bean id="jspViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/jsp/"/> <property name="suffix" value=".jsp"/> </bean> |
6、web.xml
<!-- 配置Spring 上下文位置 --> <context-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:applicationContext-*.xml</param-value> </context-param> <!-- spring监听器 --> <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class> </listener> <!-- 配置过滤器 解决POST提交乱码问题 --> <filter> <filter-name>encoding</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> </filter> <filter-mapping> <filter-name>encoding</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 前端控制器 --> <servlet> <servlet-name>SSMIntegration</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 此处不配置默认找/WEB-INF/[servlet-name]-servlet.xml --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc.xml</param-value> </init-param> <!-- 配置springmvc什么时候启动,参数必须为整数 --> <!-- 如果为0或者大于0,则springMVC随着容器启动而启动 --> <!-- 如果小于0,则在第一次请求进来的时候启动 --> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>SSMIntegration</servlet-name> <!-- 设置所有的请求都进入SpringMvc --> <url-pattern>/</url-pattern> </servlet-mapping> |
7、jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql://localhost:3306/ssm?characterEncoding=utf-8 jdbc.username=root jdbc.password=123456 |