# SpringMvcMybatis
**Repository Path**: pc_859107393/SpringMvcMybatis
## Basic Information
- **Project Name**: SpringMvcMybatis
- **Description**: SpringMvcMybatis项目框架整合,加入bruid数据库连接池.
- **Primary Language**: Java
- **License**: Not specified
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2016-10-10
- **Last Updated**: 2022-06-20
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
#### [手把手教程][JavaWeb]优雅的SpringMvc+Mybatis整合之路
手把手教你整合最优雅SSM框架:SpringMVC + Spring + MyBatis
- 前面网友说我为啥很久不更新博客了,我告诉他们我准备潜修.其实是我的博客被人批评是在记流水账(~一脸尴尬~).
- 再次安利一波,博客地址:[acheng1314.cn](http://acheng1314.cn/)
- 本文中的图片用了个人服务器存储,网速较慢,各位老司机耐心等待.
#### 工具
- IDE为**idea15**
- JDK环境为**1.8**
- maven版本为**maven3**
#### 目标
- 完成基本的SpringMVC + Spring + MyBatis框架整合
- 数据库使用mysql
- 加入阿里巴巴的druid数据库连接池
- 使用gson作为json解析工具
- 实现日志输出
- maven依赖的版本管理
#### 优点
```
此处省略若干字,观众们请脑补.
```
----
#### SSM框架整合配置
前面说了这么多,现在开始正式的干货.
##### 第一步: 使用idea的maven创建一个基本的web工程.
- 打开Idea在欢迎界面选择创建一个新的Project或者是(在菜单界面选择:New→Project),这是会出现一个界面如下图所示:

- 如上图所示,我们需要勾选的地方已经使用红色框标注出来.
- 最左边的是**maven**,是我们需要使用的项目构建工具.
- 勾选右边上面的**Create from archetype**,我们才能在下面选择我们需要构建成什么类型的项目.
- 接着我们选中**maven-archetype-webapp**,这时候我们的项目类型就确定为是web项目.
- 需要注意一点,我上面图中没标注出来的**Project SDK**,这里是选择我们开发的JDK版本.
- 点击next后,如下图所示:

- 上面图中,我们需要注意地方如下:
- **GroupId**也就是我们常说的组织ID,也可以理解为我们**应用程序的包名**
- **ArtifactId**是我们常说的产品名称(同一个组织下面可以有多个产品),也可以当作是我们的**当前项目名称**
- **Version**顾名思义就是版本号
- 最下面的红色框中,Previous==>返回上一步,Next==>下一步,Cancel==>取消,Help==>帮助
- 接下来,我们继续点击Next后,如下图所示:

- 上面途中没啥好说的,圈出来部分就是我们的**Maven目录**.继续next后,如下图所示:

- 上面选中部分,**Project name**为**项目名称**,**Project location**是项目的**存储位置**(~右边的省略号意味着可以选择位置~).
- 接下来我们**点击Finish**,我们新建基本的web项目的步骤就完成了.
- 这时候在Idea主窗口的右下角部分,我们可以看到一个滚动条在执行,说明我们的项目正在build中.右上角有一个提示框如下图所示:

- 这个提示框大概意思是:Maven项目需要被导入.我建议勾选:**Enable Auto-Import**(~自动导入~)
此处,使用Idea创建一个**Maven依赖的基本的WebApp项目**已经完成.
----
#### 框架整合前的准备工作.
- 整理项目文件组织结构.
- 通过观察目录结构,我们可以发现,需要的目录不齐全,我们需要手动补齐.初始结构图如下:

- 我们需要的主体结构图应如下:

#### 需要的主体结构目录解释:
-----
| 目录名称 | 说明 |
| ---- | ----|
| src | 源码、资源等文件的根目录|
| ↓ main | 项目开发主要目录之一,可以放java代码和一些资源文件. |
| ↓↓java | 开发的主要的java代码存放目录 |
| ↓↓↓cn.acheng1314 | 我的应用程序的包名 |
| ↓↓resources | 开发中的主要的资源文件存放目录 |
| ↓↓sql | 开发中主要的sql语句文件存放目录 |
| ↓↓webapp | web页面和其他web配置、资源文件存放目录 |
| ↓ test | 项目开发中的测试模块存放路径,包含java代码和资源文件. |
| ↓↓java | 测试代码存放目录 |
| ↓↓resources | 测试资源文件存放目录 |
- 配置目录:
- 创建main目录下的java目录(用于存放java源代码)

我们先**右键点击main目录**,接着选中**New**→**Directory**,在弹出的对话框中输入java.
- 接着我们需要把java目录标记为源文目录.

我们先**右键点击java**,然后选择**Mark Directory As**→**Sources Root**
接着我们在src目录下创建test目录(注意: **test目录和main目录同级**),以及test下面的java和resources目录,分别标记为源文件目录和资源文件目录
**值得注意的是sql目录为普通文件目录**
- 根据目标明白我们**需要哪些支援库**,具体结果如下:
4.0.0
cn.acheng1314
SSM_LOG
war
1.0-SNAPSHOT
SSM_LOG Maven Webapp
http://maven.apache.org
junit
junit
3.8.1
test
org.apache.logging.log4j
log4j-core
${org.apache.logging.log4j.version}
org.apache.logging.log4j
log4j-api
${org.apache.logging.log4j.version}
mysql
mysql-connector-java
${mysql.version}
runtime
com.alibaba
druid
${com.alibaba.druid.version}
org.mybatis
mybatis
${com.mybatis.mybatis.version}
org.mybatis
mybatis-spring
${com.mybatis.mybatis_spring.version}
taglibs
standard
1.1.2
jstl
jstl
1.2
com.google.code.gson
gson
${com.google.gson.version}
javax.servlet
javax.servlet-api
${javax.servlet.version}
org.springframework
spring-core
${org.springframework.version}
org.springframework
spring-beans
${org.springframework.version}
org.springframework
spring-context
${org.springframework.version}
org.springframework
spring-jdbc
${org.springframework.version}
org.springframework
spring-tx
${org.springframework.version}
org.springframework
spring-web
${org.springframework.version}
org.springframework
spring-webmvc
${org.springframework.version}
org.springframework
spring-test
${org.springframework.version}
redis.clients
jedis
${redis.clients.version}
com.dyuproject.protostuff
protostuff-core
${com.dyuproject.protostuff.version}
com.dyuproject.protostuff
protostuff-runtime
${com.dyuproject.protostuff.version}
commons-collections
commons-collections
3.2.2
commons-fileupload
commons-fileupload
1.3.2
commons-io
commons-io
2.5
2.6.2
5.1.37
1.0.25
3.4.1
1.3.0
2.7
3.1.0
4.3.2.RELEASE
2.7.3
1.0.8
SSM_LOG
----
#### 整合框架
在上面,我们已经把基本的目录配置好了,现在我们在已经依赖了项目支援库,接下来我们需要做的是开始**整合Spring+SpringMvc+Mybatis**
我们先**打开webapp目录下面的WEB-INF目录中的web.xml文件**,web.xml文件是整合web项目的配置中心.我们在web.xml中加入如下内容:
```
index.html
index.htm
index.jsp
default.html
default.htm
default.jsp
SSM_LOG
mvc-dispatcher
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring/spring-*.xml
mvc-dispatcher
/js/*
/css/*
/images/*
/fonts/*
DruidStatView
com.alibaba.druid.support.http.StatViewServlet
DruidStatView
/druid/*
druidWebStatFilter
com.alibaba.druid.support.http.WebStatFilter
exclusions
/public/*,*.js,*.css,/druid*,*.jsp,*.swf
principalSessionName
sessionInfo
profileEnable
true
druidWebStatFilter
/*
```
#### 快捷生成spring目录
- 在上面的```classpath:spring/spring-*.xml```处,我们选中前面一个spring,按下Alt+Enter自动生成spring目录.
- spring目录位于src→main→resources下.
#### 在spring目录下创建spring相关的控制文件
- spring-dao.xml
```
```
上面的配置中,肯定会出现报错的情况,这时候我们只需要选中报错的地方按下Alt+Enter就能生成相关的资源.
- spring-service.xml
```
```
上面的配置中,肯定会出现报错的情况,这时候我们只需要选中报错的地方按下Alt+Enter就能生成相关的资源.
**基本的spring系列和druid**已经配置完毕. 接着我们需要解决上面自动生成的一些问题.基本配置截图如下:

现在我们会发现我们的jdbc.properties和mybatis-config.xml文件都是空的,我们需要继续写入内容.
jdbc.properties是数据库连接的配置文件.如下:
```
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3307/wordpress?useUnicode=true&characterEncoding=utf8
jdbc.username=数据库用户名
jdbc.password=数据库用户名对应的密码
```
上面的jdbc.driver为数据库连接的驱动,jdbc.url为数据库的连接地址.
mybatis-config.xml 顾名思义是mybatis的配置文件,如下:
```
```
配置完成上面的东西后,大体需要的我们已经完成了.但是,我们会看到我们的日志记录还没有配置,上面我们采用了log4j2,通过查看官网文档,我们发现只需要在资源目录下面添加一个默认的配置文件即可,如下:
配置文件文件名: **log4j2.xml** , 存放目录为**src**→**main**→**resources**
```
/logs/webLog
{LOG_HOME}/backup
stat
global
```
----
至此,我们的基本配置就完成了,结果如下图所示:

具体基本配置完毕,下面我们需要进行实际演练方可知道效果,也能根据实际效果检查配置有没有出现问题.至于实际演练如何,且听下回分解.