ssm整合-->spring+springmvc+mybatis三者之间的整合

1.ssm框架

SSM框架是spring MVC ,spring和mybatis框架的整合,是标准的MVC模式,将整个系统划分为表现层,controller层,service层,DAO层四层
使用spring MVC负责请求的转发和视图管理
spring实现业务对象管理,mybatis作为数据对象的持久化引擎

1.1SSM四个分层架构的作用

(1)DAO层:DAO层主要是做数据持久层的工作,负责与数据库进行联络的一些任务都封装在此。
	DAO层的设计主要是是设计接口,与数据库映射文件即mapper层中的数据库代码有关
(2)Service层:Service层主要负责业务模块的逻辑应用设计。
		Service层的业务实现,具体要调用到已定义的DAO层的接口,
		封装Service层的业务逻辑有利于通用的业务逻辑的独立性和重复利用性,
		程序显得非常简洁。
(3)Controller层:Controller层负责具体的业务模块流程的控制,
	在此层里面要调用Service层的接口来控制业务流程,
	控制的配置也同样是在Spring的配置文件里面进行,
	针对具体的业务流程,会有不同的控制器,
	我们具体的设计过程中可以将流程进行抽 象归纳,
	设计出可以重复利用的子单元流程模块,这样不仅使程序结构变得清晰,也大大减少了代码量。
(4)View层 :即视图层 向客服展示前端数据和功能
此层与控制层结合比较紧密,需要二者结合起来协同工发。View层主要负责前台jsp页面的表示.

1.2SSM四个分层架构的作用各层联系

DAO层,Service层这两个层次都可以单独开发,互相的耦合度很低,完全可以独立进行,
这样的一种模式在开发大项目的过程中尤其有优势

Controller,View层因为耦合度比较高,因而要结合在一起开发,
但是也可以看作一个整体独立于前两个层进行开发。
这样,在层与层之前我们只需要知道接口的定义,调用接口即可完成所需要的逻辑单元应用,
一切显得非常清晰简单。

Service层是建立在DAO层之上的,建立了DAO层后才可以建立Service层,
而Service层又是在Controller层之下的,因而Service层应该既调用DAO层的接口,
又要提供接口给Controller层的类来进行调用,它刚好处于一个中间层的位置。
每个模型都有一个Service接口,每个接口分别封装各自的业务处理方法。

1.3ssm框架原理

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命令。

2.ssm整合流程

(1)创建一个meven-web项目
ssm整合-->spring+springmvc+mybatis三者之间的整合_第1张图片
(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>

ssm整合-->spring+springmvc+mybatis三者之间的整合_第2张图片

(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);
    }
}

自动生成后的目录
ssm整合-->spring+springmvc+mybatis三者之间的整合_第3张图片
测试一个通过主键查询读者的方法
ssm整合-->spring+springmvc+mybatis三者之间的整合_第4张图片
使用三层架构完成该方法的测试 创建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;
    }
}

(3)启动tomcat,并配置为根目录(个人习惯) 输入路径和id查询
ssm整合-->spring+springmvc+mybatis三者之间的整合_第5张图片
在这里插入图片描述
测试成功

你可能感兴趣的:(Java,spring,mvc,java)