一、SSM项目的构建
1、创建一个maven工程

- eclipse创建maven工程后,pom.xml报错:web.xml is missing and
is set to true
解决问题:右击项目–>java EE tools–>Generate Deployment Descriptor Stub。
系统会自动创建一个web.xml文件放到src/main/webapp/WEB_INF下。
注:xml文件格式化快捷键,Ctrl+Shift+F,为了避免和搜狗拼音的简体繁体冲突,可以勾掉搜狗的快捷键。
2、引入项目依赖的jar包
- spring
- springmvc
- mybatis
- 数据库连接池,驱动包
- 其他
1、引入Spring相关包的操作
1、maven中央仓库
2、引入springmvc的包
1 | <!-- https://mvnrepository.com/artifact/org.springframework/spring-webmvc --> |
3、引入Spring-jdbc的包
1 | <!-- https://mvnrepository.com/artifact/org.springframework/spring-jdbc --> |
4、引入Spring面向切面编程模块Spring aspects
1 | <!-- https://mvnrepository.com/artifact/org.springframework/spring-aspects --> |
2、引入MyBatis相关包的操作
1、引入mybatis的包
1 | <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis --> |
2、引入mybatis整合Spring的适配包
1 | <!-- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring --> |
3、引入数据库连接池以及驱动
1、引入c3p0数据库连接池的包
1 | <!-- https://mvnrepository.com/artifact/c3p0/c3p0 --> |
2、引入mysql8.0.15的驱动包
查看本地mysql的版本,引入相应的驱动包
首先进入mysql
1 | mysql -uroot -proot |
1 | <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java --> |
4、其他模块
由于要开发web项目,先把常用的,jstl,servlet-api,junit先引入进来
1、引入jstl包
1 | <!-- https://mvnrepository.com/artifact/jstl/jstl --> |
2、引入servlet-api包
1 | <!-- https://mvnrepository.com/artifact/javax.servlet/servlet-api --> |
我们知道tomcat服务器里面有servlet包,但是不引入的话jsp页面会报错,所以加入
3、引入junit单元测试包
1 | <!-- https://mvnrepository.com/artifact/junit/junit --> |
3、引入BootStrap前端框架
1、下载bootstrap然后解压。
2、在webapp目录下建立一个folder命名为叫static文件夹

3、把解压的bootstrap-3.3.7-dist复制到新建的static目录下
4、新建一个index.jsp引入bootstrap样式和基本文件
1 | <link href="static/bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="stylesheet"> |
4、编写ssm整合的关键配置文件
1、web.xml配置文件的编写
1 |
|
2、springmvc配置文件的编写
1 |
|
3、spring的配置文件
1、applicationContext.xml配置文件
1 |
|
2、dbconfig.properties文件的写法
由于mysql8,driverClass=com.mysql.jdbc.Driver会报错
错误解决:Loading class
com.mysql.jdbc.Driver'. This is deprecated. The new driver class iscom.mysql.cj.jdbmysql其他版本:driverClass=com.mysql.jdbc.Driver
mysql8以上版本:driverClass=com.mysql.cj.jdbc.Driver
1 | =jdbc:mysql://localhost:3306/java?useSSL=false |
错误解决:java.sql.SQLNonTransientConnectionException: Public Key Retrieval is not allowed
由于mysql8版本:
1
jdbcUrl=jdbc:mysql://localhost:3306/java?useSSL=false&allowPublicKeyRetrieval=true
4、mybatis的配置文件
1、mybatis-cfg.xml
1 |
|
2、利用MyBatis Generator逆向工程
引入mybatis generator的依赖
1
2
3
4
5
6<!-- https://mvnrepository.com/artifact/org.mybatis.generator/mybatis-generator-core -->
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.3.5</version>
</dependency>给当前工程中创建一个mbg.xml文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
<generatorConfiguration>
<context id="DB2Tables" targetRuntime="MyBatis3">
<!-- 配置数据库连接 -->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/java?useSSL=false"
userId="victor"
password="root">
</jdbcConnection>
<!-- Java的大数据类型解析 -->
<javaTypeResolver >
<property name="forceBigDecimals" value="false" />
</javaTypeResolver>
<!-- 指定javaBean生成的位置
windows系统的写法:targetProject=".\src\main\java":表示当前工程下的main的java工程下。
macOS、linux系统的写法:targetProject="./src/main/java"
-->
<javaModelGenerator targetPackage="com.victor.crud.bean" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!-- 指定sql映射文件生成的位置 -->
<sqlMapGenerator targetPackage="mapper" targetProject="./src/main/resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!-- 指定dao接口生成的位置,mapper接口 -->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.victor.crud.dao" targetProject="./src/main/java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!-- table标签指定每个表的生成策略
tableName="tbl_emp":指定表名,必须的属性。
domainObjectName="Employee":指定生成的javabean的类名
-->
<table tableName="tbl_emp" domainObjectName="Employee"></table>
<table tableName="tbl_dept" domainObjectName="Department"></table>
</context>
</generatorConfiguration>如何生成呢
因为我们是java程序+xml配置文件的生成方式

- 运行这个测试类main方法生成就行。
1 | package com.victor.crud.test; |
5、测试mapper
1、插入批量数据
首先是applicationContext.xml修改
1
2
3
4
5
6
7<!-- 配置一个可以执行批量操作的sqlSession -->
<bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
<!-- ref指向,mybatis配置好的sqlSessionFactory -->
<constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"></constructor-arg>
<!-- mybatis执行器默认类型不是bathc批量的,我们改成批量的 -->
<constructor-arg name="executorType" value="BATCH"></constructor-arg>
</bean>测试用例
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73package com.victor.crud.test;
import java.util.UUID;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import com.victor.crud.bean.Department;
import com.victor.crud.bean.Employee;
import com.victor.crud.dao.DepartmentMapper;
import com.victor.crud.dao.EmployeeMapper;
/**
* 测试dao层的工作
* @author victor
*推荐spring的项目就可以使用Spring的单元测试,可以自动注入我们需要的组件
*1、导入SpringTest模块的依赖
*2、使用@ContextConfiguration注解指定Spring配置文件的位置,可以自动帮我们创建ioc容器。
*3、@RunWith是Junit里的注解,可以指定在运行单元测试的时候,用哪个来运行。
*我们现在用Spring的单元测试模块,指定value值为SpringJUnit4ClassRunner.class
*4、我们要用哪些组件,直接@Autowried要使用的哪些组件即可。
*/
(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations= {"classpath:applicationContext.xml"})
public class MapperTest {
DepartmentMapper departmentMapper;
EmployeeMapper employeeMapper;
//自动注入一个批量的SqlSession
SqlSession sqlSession;
/**
* 测试DepartmentMapper
*/
public void testCRUD() {
/*原生的单元测试
* //1、创建SpringIOC容器
ApplicationContext ioc=new ClassPathXmlApplicationContext("applicationContext.xml");
//2、容器中获取mapper
ioc.getBean(DepartmentMapper.class);
*/
System.out.println(departmentMapper);
//1、插入几个部门
// departmentMapper.insertSelective(new Department(null,"技术部"));
// departmentMapper.insertSelective(new Department(null,"测试部"));
//2、生成员工,测试员工插入
// employeeMapper.insertSelective(new Employee(null, "Tom", "M", "1397743321@qq.com", 1));
//批量操作可以用个for循环,但是效率不高
/**
* for(){
* employeeMapper.insertSelective(new Employeenew Employee(null, "Tom", "M", "1397743321@qq.com", 1));
* }
*/
//3、批量插入多个员工;批量,使用可以执行批量操作的sqlSession
EmployeeMapper mapper=sqlSession.getMapper(EmployeeMapper.class);
for(int i=0;i<1000;i++) {
String uid=UUID.randomUUID().toString().substring(0, 5)+i;
mapper.insertSelective(new Employee(null,uid,"M",uid+"@qq.com",1));
}
System.out.println("BATCH Successfully!");
}
}
6、查询页面的展示
1、访问index.jsp页面
URI:/emps
2.index.jsp页面发送出查询员工列表请求
1 | <%@ page language="java" contentType="text/html; charset=UTF-8" |
3、EmployeeController来接受请求,查出员工数据
建立一个EmployeeController来处理员工的CRUD请求
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47package com.victor.crud.controller;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.victor.crud.bean.Employee;
import com.victor.crud.service.EmployeeService;
/**
* 处理员工的CRUD请求
* @author victor
*
*/
public class EmployeeController {
EmployeeService employeeService;
/**
* 查询员工数据(分页查询)
* @return
*/
("/emps")
public String getEmps(@RequestParam(value="pn",defaultValue="1")Integer pn,
Model model) {
//这不是一个分页查询;
//引入PageHelper分页插件
//在查询之前只需要调用
PageHelper.startPage(pn, 5);//从pn页开始查,每一页5条数据
//startPage后面紧跟的这个查询就是一个分页查询
List<Employee> emps=employeeService.getAll();
//用PageInfo包装查询后的结果,只要将pageInfo交给页面即可。
//pageInfo封装了详细的分析信息,包括有我们查询出来的数据。
PageInfo page = new PageInfo(emps,5);//传入连续显示的5页
//用Model,或者Map来给它里面添加数据,都会被带给页面,它会放到请求Request域中。
model.addAttribute("pageInfo", page);
//page对象的getNavigatepageNums可以拿到我们传入连续显示的信息
//page.getNavigatepageNums();
return "list";
}
}因为我们要使用分页功能,要在pom.xml引入PageHelper的依赖
1
2
3
4
5
6<!-- 引入PageHelper分页插件 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.0.0</version>
</dependency>为了让pageHelper起作用,还要在mybatis-config.xml配置文件中配置
1
2
3
4<!-- 引入分页插件PageHelper -->
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin>
</plugins>
建立EmployeeService来查询所有员工数据
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23package com.victor.crud.service;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import com.victor.crud.bean.Employee;
import com.victor.crud.dao.EmployeeMapper;
public class EmployeeService {
EmployeeMapper employeeMapper;
/**
* 查询所有员工数据
* @return
*/
public List<Employee> getAll(){
return employeeMapper.selectByExampleWithDept(null);
}
}为了保证页面能获取数据,先进行SpringMVC请求的测试
建立一个MVCTest测试类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90package com.victor.crud.test;
import java.util.List;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.mock.web.MockHttpServletRequest;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
import org.springframework.test.web.servlet.MockMvc;
import org.springframework.test.web.servlet.MvcResult;
import org.springframework.test.web.servlet.request.MockMvcRequestBuilders;
import org.springframework.test.web.servlet.setup.MockMvcBuilders;
import org.springframework.ui.ModelMap;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.servlet.ModelAndView;
import com.github.pagehelper.PageInfo;
import com.victor.crud.bean.Employee;
/**
* 使用Spring测试模块提供的测试请求功能,测试crud请求的正确性
* @author victor
*
*/
(SpringJUnit4ClassRunner.class)
@WebAppConfiguration
/**
* 测试Springmvc只有Spring配置文件是不够的,还要有springmvc的配置文件
*ssm-crud/src/main/webapp/WEB-INF/dispatcherServlet-servlet.xml
*
*/
@ContextConfiguration(locations= {"classpath:applicationContext.xml","file:src/main/webapp/WEB-INF/dispatcherServlet-servlet.xml"})
public class MVCTest {
/**
* @Autowired这个只能自动注入ioc容器里面的,WebApplicationContext是一个ioc容器怎么能自己@Autowired呢?
* 所以还需要一个注解@WebAppConfiguration,就可以把web的ioc容器拿过来。
*/
WebApplicationContext context;//传入SpringMVC的ioc容器
//虚拟mvc请求,获取到处理结果
MockMvc mockMvc;
/**
* 每次要用mockMvc,这个方法都要初始化以下
*/
public void initMockMvc() {
mockMvc=MockMvcBuilders.webAppContextSetup(context).build();//mockMvc来模拟mvc请求发送。
}
/**
* 测试会报一个错:java.lang.NoClassDefFoundError: javax/servlet/SessionCookieConfig
* 原因是Spring4.0测试的时候,需要servlet3.0的支持,修改pom.xml文件引入新的servlet就行。
* @throws Exception
*/
public void testPage() throws Exception {
//模拟请求拿到返回值
MvcResult result= mockMvc.perform(MockMvcRequestBuilders.get("/emps").param("pn", "1"))
.andReturn();
/**在Controller中的model.addAttribute("pageInfo", page);放在请求域中
* 请求成功以后,请求域中会有pageInfo:我们可以取出pageInfo来进行验证是否正确。
*/
ModelAndView modelAndView = result.getModelAndView();
ModelMap modelMap = modelAndView.getModelMap();
System.out.println(modelMap.toString());
System.out.println("打印modelMap完毕===============");
MockHttpServletRequest request = result.getRequest();
PageInfo pi=(PageInfo) request.getAttribute("pageInfo");
System.out.println("当前页码:"+pi.getPageNum());
System.out.println("总页码:"+pi.getPages());
System.out.println("总记录数:"+pi.getTotal());
System.out.println("在页面需要连续显示的页码:");
int[] navigatepageNums = pi.getNavigatepageNums();//ctrl+1然后enter快速生成返回值对象
for(int i:navigatepageNums) {
System.out.println(" "+i);
}
//获取员工数据
List<Employee> list = pi.getList();
for(Employee employee:list) {
System.out.println("ID:"+employee.getEmpId()+"==>Name:"+employee.getEmpName());
}
}
}测试的时候会报错
错误信息:java.lang.NoClassDefFoundError: javax/servlet/SessionCookieConfig
解决问题:原因是Spring4.0测试的时候,需要servlet3.0的支持,修改pom.xml文件引入新的servlet就行。
修改pom.xml配置文件,引入javax.servlet-api3.0.1的依赖
1
2
3
4
5
6<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>provided</scope>
</dependency>
4、来到list.jsp页面进行展示
1 | <%@ page language="java" contentType="text/html; charset=UTF-8" |

二、Lombok的使用
1、引入依赖jar
1 | <!-- https://mvnrepository.com/artifact/org.projectlombok/lombok --> |
2、使用注解
@Data,@ToString用在JavaBean
1
2
3
4
5
6
7
8
9
10
11
12
public class MyLoadImg {
(strategy = GenerationType.IDENTITY)
(name = "id")
private Long id;
private String userName;
private String url;
private String img;
private Boolean flag;
}@Slf4j用来打印日志
1
2
3
4
5
6
74j
public class MyService{
public void test(){
log.info("打印日志:{}",hello);
}
}
- 本文作者: Victor Dan
- 本文链接: https://victorblog.github.io/2016/10/03/SSM项目的构建/
- 版权声明: 本博客所有文章除特别声明外,均采用 Apache License 2.0 许可协议。转载请注明出处!
