前文啰嗦:
之前一直使用SpringBoot ,有好一段时间没去一步步整合SSM框架去做项目了,最近有小伙伴在我其他博客的留言,让我感觉到初学者虽然简单学会SpringBoot,确实能快速上手开发项目,但是可能会因为SpringBoot省掉了很多配置导致自己从来没见过SSM里面都有些什么配置,这样其实是比较不好的。 所以,我决定写一篇 SSM Spring+SpringMVC+Mybatis三大框架的整合实战教程。
开始,先看看我们的最终完成的项目目录结构:
在开始实战整合前,先简单介绍下,目录结果里面的各种配置文件(初学者最怕的无非也就是配置配置配置了,所以SpringBoot遵循习惯优于配置,直接帮忙弄了很多默认配置,让咱们IT搬砖民工沉迷于此无法自拔)
小白文简单讲讲:
web.xml 因为我们做的是一个web项目,这个web.xml是项目一跑起来,我们回去优先加载读取的一个配置文件。也就是说,项目是从它开始入手的,所以一会可以看到这个配置文件里面会有这么一行(加载applicationContext.xml):
classpath:spring/applicationContext.xml
applicationContext.xml 可以看到我们项目是三大框架的整合,既然是Spring+SpringMVC+Mybatis,那总得有个东西把三大框架整合关联起来吧? 没错,你就这么理解这个applicationContext.xml就是这一条关联的绳子(可以想想其重要性,这是一个基本杂七杂八的配置都在里面过一过那种),我们先瞄一样里面的这几行:
classpath:jdbc.properties
mybatis.xml 这个配置文件就是针对mybatis框架的。
generator.properties 和 generatorConfig.xml 这两个配置文件不是必须有的,因为这是用于逆向工程的。(不了解不要紧,一会咱们一起用下,你就知道用起来多舒服了。PS:逆向工程,根据数据表直接生成对接数据库层面需要的代码类,包括实体类、Mapper接口、MapperXML sql语句等)
jdbc.properties 这个配置文件里面就是一些连接数据库需要用到的信息(用户名、密码、连接host等等)
log4j.properties 这个配置文件是针对日志打印的。
好了,配置文件大致我们都认识了下,那么我们接下来整合就快很多了,因为现在其实已经知道这个项目大概内容是做啥了。
PS: 千万不要嫌我啰嗦,我这个是真的从零教大家整合,所以会显得比较啰嗦。
开始,首先
空空如也的我们先建一个MAVEN项目,
groupid:我填的 com.springmvc (需要跟后面自己手动建文件夹对应起来)
然后把以下目录结构准备好(因为你建完MAVEN项目,有可能只有个src文件夹和一个webapp文件夹),就是建文件夹以及一些配置文件:
ps:
让一个文件夹带上‘三个横杠’,对着文件夹,鼠标右键,找到make directory as,选择Resources root
让一个文件夹变成蓝色,对着文件夹,鼠标右键,找到 make directory as,选择Sources root
需要用到的文件我们都建完了,那么开始,我们先从依赖包入手,没有依赖包,怎么使用这些框架技术呢,pom.xml文件:
4.0.0
com.springmvc
elegantjc
1.0-SNAPSHOT
war
elegantjc Maven Webapp
http://www.example.com
UTF-8
1.7
1.7
4.2.5.RELEASE
3.2.4
1.6.6
1.2.12
org.springframework
spring-core
${spring.version}
org.springframework
spring-web
${spring.version}
org.springframework
spring-oxm
${spring.version}
org.springframework
spring-tx
${spring.version}
org.springframework
spring-jdbc
${spring.version}
org.springframework
spring-webmvc
${spring.version}
org.springframework
spring-aop
${spring.version}
org.springframework
spring-context-support
${spring.version}
org.springframework
spring-test
${spring.version}
org.mybatis
mybatis
${mybatis.version}
org.mybatis
mybatis-spring
1.2.2
org.mybatis.generator
mybatis-generator-core
1.3.5
mysql
mysql-connector-java
5.1.29
junit
junit
4.11
test
javax.servlet
jstl
1.2
javax.servlet.jsp
jsp-api
2.2.1-b03
provided
javax.servlet
servlet-api
2.5
provided
com.fasterxml.jackson.core
jackson-core
2.7.1
com.fasterxml.jackson.core
jackson-annotations
2.7.1
com.fasterxml.jackson.core
jackson-databind
2.7.1
net.sf.json-lib
json-lib
2.4
jdk15
commons-lang
commons-lang
2.4
commons-logging
commons-logging
1.1
commons-pool
commons-pool
1.5.6
commons-dbcp
commons-dbcp
1.4
commons-beanutils
commons-beanutils
1.8.3
commons-httpclient
commons-httpclient
3.1
commons-collections
commons-collections
3.1
commons-codec
commons-codec
1.9
javax.annotation
jsr250-api
1.0
net.sf.ezmorph
ezmorph
1.0.6
javax.activation
activation
1.1
taglibs
standard
1.1.2
log4j
log4j
${log4j.version}
org.slf4j
slf4j-api
${slf4j.version}
org.slf4j
slf4j-log4j12
${slf4j.version}
commons-fileupload
commons-fileupload
1.3.1
commons-io
commons-io
2.4
elegantjc
maven-clean-plugin
3.1.0
maven-resources-plugin
3.0.2
maven-compiler-plugin
3.8.0
maven-surefire-plugin
2.22.1
maven-war-plugin
3.2.2
maven-install-plugin
2.5.2
maven-deploy-plugin
2.8.2
org.mybatis.generator
mybatis-generator-maven-plugin
1.3.2
true
true
然后jdbc.properties:
driver=com.mysql.jdbc.Driver
#game_message为我本地的数据库名
url=jdbc:mysql://localhost:3306/game_message?useUnicode=true&characterEncoding=utf-8
username=root
#下面输入自己数据库的密码
password=root
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000
然后log4j.properties:
#log4j.rootLogger=debug,console,debug,info,warn,error,fatal
log4j.rootLogger=INFO,info,warn,error,fatal
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.Encoding=UTF-8
log4j.appender.console.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
#log4j.logger.java.sql.ResultSet=INFO
#log4j.logger.org.apache=INFO
#log4j.logger.java.sql.Connection=INFO
#log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=INFO
log4j.logger.org.apache=INFO
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
log4j.logger.org.springframework=ERROR
log4j.logger.org.mybatis=ERROR
log4j.logger.org.hibernate=ERROR
log4j.logger.com.mchange=ERROR
log4j.logger.org.quartz=ERROR
log4j.logger.debug=debug
log4j.appender.debug=org.apache.log4j.DailyRollingFileAppender
log4j.appender.debug.layout=org.apache.log4j.PatternLayout
log4j.appender.debug.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
log4j.appender.debug.datePattern='.'yyyy-MM-dd-HH
log4j.appender.debug.Threshold=DEBUG
log4j.appender.debug.append=true
log4j.appender.debug.Encoding=UTF-8
log4j.appender.debug.File=${loghome}/mall_debug.log
log4j.logger.info=info
log4j.appender.info=org.apache.log4j.DailyRollingFileAppender
log4j.appender.info.layout=org.apache.log4j.PatternLayout
log4j.appender.info.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
log4j.appender.info.datePattern='.'yyyy-MM-dd-HH
log4j.appender.info.Threshold=INFO
log4j.appender.info.append=true
log4j.appender.info.Encoding=UTF-8
log4j.appender.info.File=${loghome}/mall_info.log
log4j.logger.warn=warn
log4j.appender.warn=org.apache.log4j.DailyRollingFileAppender
log4j.appender.warn.layout=org.apache.log4j.PatternLayout
log4j.appender.warn.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
log4j.appender.warn.datePattern='.'yyyy-MM-dd-HH
log4j.appender.warn.Threshold=WARN
log4j.appender.warn.append=true
log4j.appender.warn.Encoding=UTF-8
log4j.appender.warn.File=${loghome}/mall_warn.log
log4j.logger.error=error
log4j.appender.error=org.apache.log4j.DailyRollingFileAppender
log4j.appender.error.layout=org.apache.log4j.PatternLayout
log4j.appender.error.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
log4j.appender.error.datePattern='.'yyyy-MM-dd-HH
log4j.appender.error.Threshold=ERROR
log4j.appender.error.append=true
log4j.appender.error.Encoding=UTF-8
log4j.appender.error.File=${loghome}/mall_error.log
log4j.logger.fatal=fatal
log4j.appender.fatal=org.apache.log4j.DailyRollingFileAppender
log4j.appender.fatal.layout=org.apache.log4j.PatternLayout
log4j.appender.fatal.layout.ConversionPattern= %p %d{MM-dd_HH:mm:ss} %F %L %m %n
log4j.appender.fatal.datePattern='.'yyyy-MM-dd-HH
log4j.appender.fatal.Threshold=FATAL
log4j.appender.fatal.append=true
log4j.appender.fatal.Encoding=UTF-8
log4j.appender.fatal.File=${loghome}/mall_fatal.log
#The log output to the directory
#loghome=/log/tomcat/zqgameapi_logs
#loghome=/data/logs/tomcat/admin.gamelaoyou.com
loghome=F:\\log_data
mybatis.xml:
applicationContext.xml:
application/json;charset=UTF-8
classpath:jdbc.properties
web.xml:
elegantjc
encodingFilter
org.springframework.web.filter.CharacterEncodingFilter
encoding
UTF-8
forceEncoding
true
encodingFilter
/*
springServlet
org.springframework.web.servlet.DispatcherServlet
contextConfigLocation
classpath:spring/applicationContext.xml
1
springServlet
/
org.springframework.web.context.ContextLoaderListener
default
*.md
contextConfigLocation
classpath:spring/applicationContext.xml
/WEB-INF/index.jsp
600
generator.properties:
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/game_message?useUnicode=true&characterEncoding=utf-8
username=root
password=root
#entity 包名和 java目录
modelPackage=com.springmvc.entity
modelProject=src/main/java
#sqlmap包名 和resources目录
sqlPackage=sqlmap
sqlProject=src/main/resources
#mapper包名和 java目录
mapperPackage=com.springmvc.dao
mapperProject=src/main/java
#数据库需要自动逆向生成的表的名字
table=messageboard
generatorConfig.xml:
到这里,我们其实已经整合完毕了,这时候你需要做的是,先别急着往下看,先回过头看看配置文件里面的注释,了解一下各项配置的作用。
继续,我们现在开始在数据简单建一张表,名字叫messageboard:
表建完了,我们开始打开IDEA右侧的maven模块,找到mybatis-generator,双击它进行逆向工程的生成:
看到控制台出现了 BUILD SUCCESS ,那么你可以看到你的项目,多了三个文件,可以点开看看,增删改查基本都帮你自动生成了(搬砖必备):
好了,那么我们接下来添加service层和controller层代码,这样就是controller->service->dao->entity 四层结构:
MessageBoardService.java:
package com.springmvc.service;
import com.springmvc.entity.Messageboard;
/**
* @Author : JCccc
* @CreateTime : 2019/7/31
* @Description :
**/
public interface MessageboardService {
int insert(Messageboard record);
}
MessageBoardServiceImpl.java:
package com.springmvc.service.impl;
import com.springmvc.dao.MessageboardMapper;
import com.springmvc.entity.Messageboard;
import com.springmvc.service.MessageboardService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* @Author : JCccc
* @CreateTime : 2019/7/31
* @Description :
**/
@Service
public class MessageboardServiceImpl implements MessageboardService {
@Autowired
MessageboardMapper messageboardMapper;
@Override
public int insert(Messageboard record) {
return messageboardMapper.insert(record);
}
}
然后是controller层:
MessageboardController.java:
package com.springmvc.controller;
import com.springmvc.entity.Messageboard;
import com.springmvc.service.MessageboardService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
/**
* @Author : JCccc
* @CreateTime : 2019/7/31
* @Description :
**/
@RestController
public class MessageboardController {
@Autowired
MessageboardService messageboardServiceImpl;
@RequestMapping(value = "/addMessageBoardData",produces = "application/json; charset=utf-8")
public String addMessageBoardData() {
Messageboard messageboard =new Messageboard();
messageboard.setUsername("测试添加");
messageboard.setMessage("哇,SSM整合这么简单");
int effectNum = messageboardServiceImpl.insert(messageboard);
int id=messageboard.getId();
System.out.println();
return "影响行数:"+effectNum+" 返回主键id:"+id;
}
}
可以看到我这个接口里面,调用的方法是插入方法。
那么我们将项目跑起来(配置下tomcat),最后用Postman去调这个接口测试下:
看下控制台:
好了,到这里,这篇教程就真的到此结束了,希望你能收获到些什么(PS: 不用自动生成,自己去手写mapper、mapper.xml、pojo都是非常正常的,喜欢自己建的完全可以自己建,喜欢自动生成的就可以用自动生成)。