SSM框架是spring MVC ,spring和mybatis框架的整合,是标准的MVC模式,将整个系统划分为表现层,controller层,service层,DAO层四层
使用spring MVC负责请求的转发和视图管理
spring实现业务对象管理,mybatis作为数据对象的持久化引擎
(1)DAO层:DAO层主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此。
DAO层的设计主要是是设计接口,与数据库映射文件即mapper层中的数据库代码有关
(2)Service层:Service层主要负责业务模块的逻辑应用设计。
Service层的业务实现,具体要调用到已定义的DAO层的接口,
封装Service层的业务逻辑有利于通用的业务逻辑的独立性和重复利用性,
程序显得非常简洁。
(3)Controller层:Controller层负责具体的业务模块流程的控制,
在此层里面要调用Service层的接口来控制业务流程,
控制的配置也同样是在Spring的配置文件里面进行,
针对具体的业务流程,会有不同的控制器,
我们具体的设计过程中可以将流程进行抽 象归纳,
设计出可以重复利用的子单元流程模块,这样不仅使程序结构变得清晰,也大大减少了代码量。
(4)View层 :即视图层 向客服展示前端数据和功能
此层与控制层结合比较紧密,需要二者结合起来协同工发。View层主要负责前台jsp页面的表示.
DAO层,Service层这两个层次都可以单独开发,互相的耦合度很低,完全可以独立进行,
这样的一种模式在开发大项目的过程中尤其有优势
Controller,View层因为耦合度比较高,因而要结合在一起开发,
但是也可以看作一个整体独立于前两个层进行开发。
这样,在层与层之前我们只需要知道接口的定义,调用接口即可完成所需要的逻辑单元应用,
一切显得非常清晰简单。
Service层是建立在DAO层之上的,建立了DAO层后才可以建立Service层,
而Service层又是在Controller层之下的,因而Service层应该既调用DAO层的接口,
又要提供接口给Controller层的类来进行调用,它刚好处于一个中间层的位置。
每个模型都有一个Service接口,每个接口分别封装各自的业务处理方法。
SpringMVC:
客户端发送请求到DispacherServlet(分发器)
由DispacherServlet控制器查询HanderMapping,找到处理请求的Controller
Controller调用业务逻辑处理后,返回ModelAndView
DispacherSerclet查询视图解析器,找到ModelAndView指定的视图
视图负责将结果显示到客户端
Spring:
我们平时开发接触最多的估计就是IOC容器,它可以装载bean(也就是我们Java中的类,
当然也包括service层 dao层),有了这个机制,
我们就不用在每次使用这个类的时候为它初始化,很少看到关键字new。
另外spring的aop,事务管理等等都是我们经常用到的。
Mybatis:
mybatis是对jdbc的封装,它让数据库底层操作变的透明。
mybatis的操作都是围绕一个sqlSessionFactory实例展开的。
mybatis通过配置文件关联到各实体类的Mapper文件,
Mapper文件中配置了每个类对数据库所需进行的sql语句映射。
在每次与数据库交互时,通过sqlSessionFactory拿到一个sqlSession,再执行sql命令。
(1)创建一个meven-web项目
(2)修改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>com.wx</groupId>
<artifactId>ssm-demo02</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<!--spring-webmvc-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.15.RELEASE</version>
</dependency>
<!--mybatis依赖-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.6</version>
</dependency>
<!--mybatis和spring整合的依赖-->
<dependency>
<groupId>repMaven.org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.7</version>
</dependency>
<!--mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.28</version>
</dependency>
<!--druid连接池依赖-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.6</version>
</dependency>
<!--lombok依赖-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.24</version>
</dependency>
<!--jackson java对象转换为json对象 @ResponseBody-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.13.2.2</version>
</dependency>
<!--servlet-api依赖-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
<dependency>
<groupId>repMaven.org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.2.15.RELEASE</version>
</dependency>
<!--代码生成器generator-->
<dependency>
<groupId>repMaven.org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.4.0</version>
</dependency>
</dependencies>
</project>
(3)写spring配置文件 (整合了mybaitis的配置文件 两个文件可以在同一个配置文件中)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--包扫描-->
<context:component-scan base-package="com.wx"/>
<!--开启注解-->
<mvc:annotation-driven/>
<!--静态资源的放行-->
<mvc:default-servlet-handler/>
<!--spring的配置-->
<!--数据源配置-->
<bean id="ds" class="com.alibaba.druid.pool.DruidDataSource">
<!--驱动名称-->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/mydb?serverTimezone=Asia/Shanghai"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
<!--初始化连接池的个数-->
<property name="initialSize" value="5"/>
<!--至少的个数-->
<property name="minIdle" value="5"/>
<!--最多的个数-->
<property name="maxActive" value="10"/>
<!--最长等待时间单位毫秒-->
<property name="maxWait" value="3000"/>
</bean>
<!--sqlSessionFactory 整合mybatis-->
<bean id="sessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="ds"/>
<!--设置mybatis映射文件的路径-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!--为dao接口生成代理实现类-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!--为com.ykq.dao包下的接口生成代理实现类-->
<property name="basePackage" value="com.wx.dao"/>
</bean>
</beans>
里面会有爆红,不用管 解析来用generator代码生成器自动解决 只需要创建相应的包就行
(4)配置web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<!-- DispatherServlet(中央调度器)
DispatherServlet: 负责接收用户的所有请求,
用户把请求给了DispatherServlet,
之后DispatherServlet把请求转发给Controller对象,
最后是Controller对象处理请求。-->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--编码过滤器-->
<filter>
<filter-name>encodingFilter</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>encodingFilter</filter-name>
<url-pattern>/*
(5)使用代码生成器 generator,通过数据库中的表自动生成实体类,dao层 ,数据库映射文件mapper层
(1)依赖
<dependency>
<groupId>org.mybatis.generator</groupId>
<artifactId>mybatis-generator-core</artifactId>
<version>1.4.0</version>
</dependency>
(2)配置文件 generator.xml 该文件放在根目录下
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfiguration
PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN"
"http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration>
<!--location的位置是在本地仓库的位置,在最开始配置maven项目的路径的local repository路径中找 如下图
mysql驱动jar的位置 直到找到 mysql-connector-java-8.0.16.jar 版本不一致 但是为.jar结尾,
-->
<classPathEntry location="D:\repMaven\mysql\mysql-connector-java\8.0.16\mysql-connector-java-8.0.16.jar" />
<!--去掉代码注释 代码注释太多看着很烦-->
<context id="DB2Tables" targetRuntime="MyBatis3">
<commentGenerator>
<property name="suppressAllComments" value="true" />
</commentGenerator>
<!--数据库的配置信息 只需要改变右边的值 属性名不需要变-->
<jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/mydb?serverTimezone=Asia/Shanghai"
userId="root"
password="root">
</jdbcConnection>
<!--Java实体类的配置信息
targetPackage:目标包 实体类的位置是在java下
targetProject:目标工程 src下 java之前
-->
<javaModelGenerator targetPackage="com.wx.entity" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
<property name="trimStrings" value="true" />
</javaModelGenerator>
<!--映射文件mapper层的配置信息-->
<sqlMapGenerator targetPackage="mapper" targetProject=".\src\main\resources">
<property name="enableSubPackages" value="true" />
</sqlMapGenerator>
<!--dao层的配置信息-->
<javaClientGenerator type="XMLMAPPER" targetPackage="com.wx.dao" targetProject=".\src\main\java">
<property name="enableSubPackages" value="true" />
</javaClientGenerator>
<!--schema:数据库名 tableName:表名 domainObjectName:实体类名 只需要改动这三处-->
<table schema="mydb" tableName="readers" domainObjectName="Reader"
enableSelectByExample="false"
enableCountByExample="false"
enableDeleteByExample="false"
enableUpdateByExample="false">
<property name="useActualColumnNames" value="true"/>
<generatedKey column="ID" sqlStatement="DB2" identity="true" />
<columnOverride column="DATE_FIELD" property="startDate" />
<ignoreColumn column="FRED" />
<columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" />
</table>
</context>
</generatorConfiguration>
(3)启动代码生成器
自定义一个测试类的主函数 启动代码生成器
public class TestGenerator {
public static void main(String[] args) throws Exception{
List<String> warnings = new ArrayList<String>();
boolean overwrite = true;
File configFile = new File("generator.xml");
ConfigurationParser cp = new ConfigurationParser(warnings);
Configuration config = cp.parseConfiguration(configFile);
DefaultShellCallback callback = new DefaultShellCallback(overwrite);
MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
myBatisGenerator.generate(null);
}
}
自动生成后的目录
测试一个通过主键查询读者的方法
使用三层架构完成该方法的测试 创建service层和controller
(1)创建service层及其实现类
public interface ReadService {
//通过主键查询读者
public Reader selectById(Integer id);
}
``
```java
@Service
public class ReadServiceImpl implements ReadService{
@Autowired //该处可不加值 默认为的value值是首字母小写
ReaderMapper readerMapper;
public Reader selectById(Integer id){
return readerMapper.selectByPrimaryKey(id);
}
}
(2)创建controller层
@RestController
@RequestMapping("/select")
public class ReadController {
@Autowired
ReadService readService;
//使用map可以返回Json数据给前端页面
@RequestMapping("selectById")
public Map selectById(Integer id){
Reader reader = readService.selectById(id);
if(reader!=null){
Map map = new HashMap();
map.put("code",2000);
map.put("msg","查询成功");
map.put("data",reader);
return map;
}
Map map = new HashMap();
map.put("code",5000);
map.put("msg","查询失败");
map.put("data",null);
return map;
}
}