讲解Spring/Spring MVC/MyBatis(SSM)整合配置过程
讲解MyBatis-Plus敏捷开发插件的用法
主要知识点
SSM整合配置
MyBatis-Plus配置与应用
Kaptcha验证码组件使用
富文本编辑器wangEditor
Spring Task任务调度
什么是整合
通过Spring loC容器管理第三方框架对象,让多框架形成整体
SpringMVC提供控制器,即基于Spring的Web交互能力
Spring对应用程序对象进行创建、管理
MyBatis对数据库增删改查
SSM整合三阶段
Spring与Spring MVC环境配置
Spring与MyBatis的整合配置
整合其他组件:声明式事务/旧日志/任务调度/…
一、Spring与Spring MVC环境配置
- 依赖spring-webmvc
- 配置DispatcherServlet
- 启用Spring MVC注解模式
- 配置请求与响应字符集
- 配置FreeMarker模板引擎
- 配置Json序列化组件
1.依赖spring-webmvc
pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>org.example</groupId>
<artifactId>ssm-instance</artifactId>
<version>1.0-SNAPSHOT</version>
<properties>
<maven.compiler.source>8</maven.compiler.source>
<maven.compiler.target>8</maven.compiler.target>
</properties>
<repositories>
<repository>
<id>aliyun</id>
<name>aliyun</name>
<url>https://maven.aliyun.com/repository/public</url>
</repository>
</repositories>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<!--Freemarker-->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.31</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
<!--JACKSON-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.8.11</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.8.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.8.11.3</version>
</dependency>
</dependencies>
</project>
这里jackson配置的版本要尽量选择2.10之后,不然不兼容jar包
发布到tomcat根目录
2. 配置DispatcherServlet
web.xml中配置
3.启用Spring MVC注解模式
创建resource下applictionContext.xml
4.配置请求与响应字符集
<!--解决中文乱码-->
<filter>
<filter-name>characterFilter</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>characterFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
对于post方法中的字符集转为utf-8;
对于get方法的请求,需要修改tomcat的server.xml,增加urlencoding配置项。tomcat8之后默认对get方法转为utf-8,无需设置。
类用于管理响应产生输出的miming字符集
属性通过设置list集合说明响应输出的字符集
value:说明响应的contenttype为一个html片段,浏览器进行解析,并将文字转码
5.配置FreeMarker模板引擎
6.配置Json序列化组件
二、整合Spring和MyBatis
sqlSessionFactory用于解析配置文件并初始化
但spring与之并不能管理,通过mybatis-spring整合,利用spring管理
- 依赖mybatis-spring及驱动
- 配置数据源与连接池
- 配置SqlSessionFactory
- 配置Mapper扫描器
- 创建mybatis-config.xml
pom中引入依赖:
spring-jdbc
mybatis
mybatis-spring整合包
mysql-connector-java jdbc驱动
druid连接池
配置数据源
bean id=“dataSource”
原生的MyBatis与Spring整合
SessionFactoryBean用于根据配置信息创建SqlSessionFactory,不再需自己编码创建
bean id=“sessionFactory”
配置Mapper扫描器
spring在初始化mybatis过程中,通过接口方式对数据库增删改查,Mapper扫描器用于扫描接口
MyBatis配置文件地址
<settings>
<!--驼峰域名转换-->
<setting name="mapUnderscoreToCamelCase" value="true"></setting>
</settings>
三、整合其他组件
配置logback日志输出
声明式事务配置
整合JUnit单元测试
pom中引入依赖:
spring-test
junit
logback-classic日志组件
声明式事务
<!-- 声明式事务 基于数据源的事务管理器 -->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"></property>
</bean>
<!-- 基于注解的声明式事务管理器 -->
<tx:annotation-driven transaction-manager="transactionManager"></tx:annotation-driven>
@Transactional 事务控制注解,正常执行,报错回滚
MyBatis-Plus
MyBatis-Plus(简称MP)是一个MyBatis的增强工具
自动实现Mapper CRUD操作,极致提高数据库开发效率
MP在MyBatis的基础上只做增强不做改变
对于CRUD的sql语句浪费时间
整合:
- pom引入mybatis-plus依赖
- Spring XML更改配置SqlSessionFactory实现类
- mybatis-config.xml增加MP分页插件
开发使用:
- 创建实体类,@TableName/@Tableld/@TableField实现映射
- 创建Mapper接口继承BaseMapper,创建Mapper XML
- 开发时注入Mapper对象,通过内置API实现CRUD操作
@TableName -将实体类与表名映射
@Tableld -说明对应属性是表的主键
@TableField -设置属性与列名的对应关系