我是靠谱客的博主 闪闪奇迹,最近开发中收集的这篇文章主要介绍SSM框架SSM框架,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

SSM框架

MyBatis

MyBatis简介

什么是MyBatis

  1. 一款持久层框架
  2. MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程
  3. MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 实体类 【Plain Old Java Objects,普通的 Java对象】映射成数据库中的记录。
  4. 可以通过Maven仓库获得MyBatis

持久化

  1. 持久化是将程序数据在持久状态和瞬时状态间转换的机制。
  2. 即把数据(如内存中的对象)保存到可永久保存的存储设备中(如磁盘)。持久化的主要应用是将内存中的对象存储在数据库中,或者存储在磁盘文件中、XML数据文件中等等。

持久层

  1. 完成持久化工作的代码块 . ----> dao层 【DAO (Data Access Object) 数据访问对象】
  2. 持久化的实现过程则大多通过各种关系数据库来完成

为什么需要MyBatis

  1. Mybatis就是帮助程序猿将数据存入数据库中 , 和从数据库中取出数据
  2. 传统的jdbc操作 , 有很多重复代码块 .比如 : 数据取出时的封装 , 数据库的建立连接等等… , 通过框架可以减少重复代码,提高开发效率
  3. MyBatis 是一个半自动化的ORM框架 (Object Relationship Mapping) -->对象关系映射
  4. MyBatis的优点
    • 简单易学 只需安装两个jar文件和配置几个SQL映射文件
    • 灵活 sql语句写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
    • **解除sql与程序代码的耦合 ** 通过提供DAO层,将业务逻辑和数据访问逻辑分离,sql和代码的分离,提高了可维护性。
    • 提供xml标签,支持编写动态sql
    • 重要的一点,用的人多,生态比较好

一个MyBatis程序

  1. 创建一个普通的maven项目

  2. 导入依赖

    	<dependencies>
            <!--mysql驱动-->
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <version>5.1.14</version>
            </dependency>
    
            <!--mybatis-->
            <dependency>
                <groupId>org.mybatis</groupId>
                <artifactId>mybatis</artifactId>
                <version>3.5.6</version>
            </dependency>
    
  3. 编写MyBatis核心配置文件

    mybatis-config.xml在resources文件中

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
           PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
           "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <configuration>
       <environments default="development">
           <environment id="development">
               <transactionManager type="JDBC"/>
               <dataSource type="POOLED">
                   <property name="driver" value="com.mysql.jdbc.Driver"/>
                   <property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSL=true&amp;useUnicode=true&amp;characterEncoding=utf8"/>
                   <property name="username" value="root"/>
                   <property name="password" value="123456"/>
               </dataSource>
           </environment>
       </environments>
    <!--每一个Mpper,XML都需要Mybatis核心配置文件中注册-->
        <mappers>
        <!--<mapper resource="com/tqw_zg/dao/UserMapper.xml"/>-->
            <!--<mapper class="com.tqw_zg.dao.UserMapper"/>-->
            <package name="com.tqw_zg.dao"/>
        </mappers>
     </configuration>
    
    
  4. 编写MyBatis工具类

    //sqlSessionFactory --> sqlSession
    public class MybatisUtils {
    
        static SqlSessionFactory sqlSessionFactory = null;
    
        static {
            try {
                //使用Mybatis第一步 :获取sqlSessionFactory对象
                String resource = "mybatis-config.xml";
                InputStream inputStream = Resources.getResourceAsStream(resource);
                sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
        //既然有了 SqlSessionFactory,顾名思义,我们可以从中获得 SqlSession 的实例.
        // SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。
        public static SqlSession getSqlSession(){
            return sqlSessionFactory.openSession();
        }
    }
    
    
  5. dao接口

    public interface UserDao {
        //获取全部用户
        List<User> getUserList();
    
        //模糊查询一个用户
        List<User> getUserLike(String str);
    
        //根据ID查询用户
        User getUserById(int id);
    
        //添加一个用户
        int addUser(User user);
    
        int addUser2(Map<String,Object> map);
    
        //修改用户
        int updateUser(User user);
    
        //删除一个用户
        int deleteUser(int id);
    
    }
    
  6. 接口实现类

    UserMapper.xml在dao文件下

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE mapper
            PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
    <!--namespace=绑定一个对应的Dao/Mapper接口-->
    <mapper namespace="com.tqw_zg.dao.UserDao">
        <select id="getUserList" resultType="com.tqw_zg.pojo.User">
          select * from mybatis.user
         </select>
    
        <select id="getUserById" resultType="com.tqw_zg.pojo.User" parameterType="int">
          select * from mybatis.user where id=#{id}
         </select>
    
        <insert id="addUser" parameterType="com.tqw_zg.pojo.User">
          insert into mybatis.user (id, name, pwd) values (#{id}, #{name}, #{pwd})
         </insert>
    
    
        <update id="updateUser" parameterType="com.tqw_zg.pojo.User">
            update mybatis.user set name=#{name},pwd=#{pwd} where id=#{id}
        </update>
    
        <delete id="deleteUser" parameterType="int">
            delete from mybatis.user where id=#{id}
        </delete>
    
    </mapper>
    
  7. 配置类还可以这样写

    db.properties

    driver=com.mysql.jdbc.Driver
    url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8
    username=root
    password=123456
    

    mybatis-config.xml

    <?xml version="1.0" encoding="UTF-8" ?>
    <!DOCTYPE configuration
            PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
            "http://mybatis.org/dtd/mybatis-3-config.dtd">
    <!--核心配置文件-->
    <configuration>
        <properties resource="db.properties"/>
        <!--可以给实体类起别名-->
        <!--<typeAliases>-->
            <!--<typeAlias type="com.tqw_zg.pojo.User" alias="User"/>-->
        <!--</typeAliases>-->
        <typeAliases>
            <package name="com.tqw_zg.pojo"/>
        </typeAliases>
    
        <environments default="development">
            <environment id="development">
                <transactionManager type="JDBC"/>
                <dataSource type="POOLED">
                    <property name="driver" value="${driver}"/>
                    <property name="url" value="${url}"/>
                    <property name="username" value="${username}"/>
                    <property name="password" value="${password}"/>
                </dataSource>
            </environment>
        </environments>
        <!--每一个Mpper,XML都需要Mybatis核心配置文件中注册-->
        <mappers>
            <!--<mapper resource="com/tqw_zg/dao/UserMapper.xml"/>-->
            <!--<mapper class="com.tqw_zg.dao.UserMapper"/>-->
            <package name="com.tqw_zg.dao"/>
        </mappers>
    </configuration>
    
  8. 测试

    @Test
        public void test(){
    
            //1.获取SqlSession对象
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            //2.执行SQL
            // 方式一:getMapper
            UserDao userDao = sqlSession.getMapper(UserDao.class);
            List<User> userList = userDao.getUserList();
            for (User user : userList) {
                System.out.println(user);
            }
    
            //关闭sqlSession
            sqlSession.close();
        }
    
    

    注意:增删改一定要提交事务

    sqlSession.commit();

  9. 万能Map

    假设,我们的实体类,或者数据库中的表,字段或者参数过多,我们应该考虑使用Map!

    UserMapper接口
    //用万能Map插入用户
    public void addUser2(Map<String,Object> map);
    
    UserMapper.xml
    <!--对象中的属性可以直接取出来 传递map的key-->
    <insert id="addUser2" parameterType="map">
        insert into user (id,name,pwd) values (#{userid},#{username},#{userpassword})
    </insert>
    
    测试
        @Test
        public void test3(){
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            HashMap<String, Object> map = new HashMap<String, Object>();
            map.put("userid",4);
            map.put("username","王虎");
            map.put("userpassword",789);
            mapper.addUser2(map);
            //提交事务
            sqlSession.commit();
            //关闭资源
            sqlSession.close();
        }
    
    
  10. 模糊查询

Java代码执行的时候,传递通配符% %

List userList = mapper.getUserLike("%李%");

在sql拼接中使用通配符

select * from user where name like “%”#{value}"%"

  1. 配置解析

    MyBatis默认的事务管理器就是JDBC ,连接池:POOLED

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-kQ2cnN3g-1633929723333)(C:UserszgAppDataRoamingTyporatypora-user-images1633577279151.png)]

  2. 解决属性名和字段名不一致的问题

    1. 起别名

      pwd as password

    2. 结果映射集

      <resultMap id="UserMap" type="com.tqw_zg.pojo.User">
          <!--column数据库中的字段,property实体类中的属性-->
          <result column="id" property="id"></result>
          <result column="name" property="name"></result>
          <result column="pwd" property="password"></result>
      </resultMap>
      
      <select id="getUserList" resultMap="UserMap">
          select * from USER where id=${id}
      </select>
      
  3. 分页

    使用Limit分页

    SELECT * from user limit startIndex,pageSize 
    SELECT * from user limit 3; [0,n]
    

    代码实现

    接口
    //分页
    List<User> getUserByLimit(Map<String,Integer> map);
    
    Mapper.xml
    <!--分页查询-->
    <select id="getUserByLimit" parameterType="map" resultMap="UserMap">
        select * from user limit #{startIndex},#{pageSize}
    </select>
    
    测试
    
        @Test
        public void getUserByLimit(){
            SqlSession sqlSession = MybatisUtils.getSqlSession();
            UserMapper mapper = sqlSession.getMapper(UserMapper.class);
            HashMap<String, Integer> map = new HashMap<String, Integer>();
            map.put("startIndex",1);
            map.put("pageSize",2);
            List<User> list = mapper.getUserByLimit(map);
            for (User user : list) {
                System.out.println(user);
            }
        }
    
    
  4. 使用注解开发

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-P3nsr8qh-1633929723336)(C:UserszgAppDataRoamingTyporatypora-user-images1633577710334.png)]

    注解在接口上实现

    @Select("select * from user")
    List<User> getUsers();
    

    需要在核心配置文件中绑定接口

    <mappers>
      <mapper class="com.kuang.dao.UserMapper"/>
    </mappers>
    

    本质:反射机制实现

    底层:动态代理

    方法存在多个参数,所有的参数前面必须加上@Param(“id”)注解

    基本类型的参数或者String类型,需要加上@Param()

    #{} 和 ${}

    #{}可以很大程度防止sql注入

    ${}不可以防止sql注入

  5. 多对一

    多个学生关联一个老师 association

     <!--按照结果进行查询-->
        <select id="getStudent2" resultMap="StudentTeacher2">
            select s.id sid , s.name sname, t.name tname
            from student s,teacher t
            where s.tid=t.id
        </select>
        <!--结果封装,将查询出来的列封装到对象属性中-->
        <resultMap id="StudentTeacher2" type="student">
            <result property="id" column="sid"/>
            <result property="name" column="sname"/>
            <association property="teacher" javaType="teacher">
                <result property="name" column="tname"></result>
            </association>
        </resultMap>
    
  6. 一对多

    一个老师管理多个学生 collection

    <!--按结果嵌套查询-->
    <select id="getTeacher" resultMap="StudentTeacher">
        SELECT s.id sid, s.name sname,t.name tname,t.id tid FROM student s, teacher t
        WHERE s.tid = t.id AND tid = #{tid}
    </select>
    <resultMap id="StudentTeacher" type="Teacher">
        <result property="id" column="tid"/>
        <result property="name" column="tname"/>
        <!--复杂的属性,我们需要单独处理 对象:association 集合:collection
        javaType=""指定属性的类型!
        集合中的泛型信息,我们使用ofType获取
        -->
        <collection property="students" ofType="Student">
            <result property="id" column="sid"/>
            <result property="name" column="sname"/>
            <result property="tid" column="tid"/>
        </collection>
    </resultMap>
    
  7. 动态SQL

  8. 缓存

Spring

  1. Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器(框架)

    Spring 框架是一个分层架构,由 7 个定义良好的模块组成。Spring 模块构建在核心容器之上,核心容器定义了创建、配置和管理 bean 的方式 .

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-O613GwcJ-1633929723337)(C:UserszgAppDataRoamingTyporatypora-user-images1633592851141.png)]

    组成 Spring 框架的每个模块(或组件)都可以单独存在,或者与其他一个或多个模块联合实现。每个模块的功能如下:

    • 核心容器:核心容器提供 Spring 框架的基本功能。核心容器的主要组件是 BeanFactory,它是工厂模式的实现。BeanFactory 使用控制反转(IOC) 模式将应用程序的配置和依赖性规范与实际的应用程序代码分开。
    • Spring 上下文:Spring 上下文是一个配置文件,向 Spring 框架提供上下文信息。Spring 上下文包括企业服务,例如 JNDI、EJB、电子邮件、国际化、校验和调度功能。
    • Spring AOP:通过配置管理特性,Spring AOP 模块直接将面向切面的编程功能 , 集成到了 Spring 框架中。所以,可以很容易地使 Spring 框架管理任何支持 AOP的对象。Spring AOP 模块为基于 Spring 的应用程序中的对象提供了事务管理服务。通过使用 Spring AOP,不用依赖组件,就可以将声明性事务管理集成到应用程序中。
    • Spring DAO:JDBC DAO 抽象层提供了有意义的异常层次结构,可用该结构来管理异常处理和不同数据库供应商抛出的错误消息。异常层次结构简化了错误处理,并且极大地降低了需要编写的异常代码数量(例如打开和关闭连接)。Spring DAO 的面向 JDBC 的异常遵从通用的 DAO 异常层次结构。
    • Spring ORM:Spring 框架插入了若干个 ORM 框架,从而提供了 ORM 的对象关系工具,其中包括 JDO、Hibernate 和 iBatis SQL Map。所有这些都遵从 Spring 的通用事务和 DAO 异常层次结构。
    • Spring Web 模块:Web 上下文模块建立在应用程序上下文模块之上,为基于 Web 的应用程序提供了上下文。所以,Spring 框架支持与 Jakarta Struts 的集成。Web 模块还简化了处理多部分请求以及将请求参数绑定到域对象的工作。
    • Spring MVC 框架:MVC 框架是一个全功能的构建 Web 应用程序的 MVC 实现。通过策略接口,MVC 框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。
  2. IOC本质

控制反转IoC(Inversion of Control),是一种设计思想,DI(依赖注入)是实现IoC的一种方法,也有人认为DI只是IoC的另一种说法。没有IoC的程序中 , 我们使用面向对象编程 , 对象的创建与对象间的依赖关系完全硬编码在程序中,对象的创建由程序自己控制,控制反转后将对象的创建转移给第三方,个人认为所谓控制反转就是:获得依赖对象的方式反转了。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0Kjl6f3I-1633929723338)(file:///C:/Users/zg/AppData/Local/Temp/msohtmlclip1/01/clip_image002.png)]

IoC是Spring框架的核心内容,使用多种方式完美的实现了IoC,可以使用XML配置,也可以使用注解,新版本的Spring也可以零配置实现IoC。

Spring容器在初始化时先读取配置文件,根据配置文件或元数据创建与组织对象存入容器中,程序使用时再从Ioc容器中取出需要的对象。

采用XML方式配置Bean的时候,Bean的定义信息是和实现分离的,而采用注解的方式可以把两者合为一体,Bean的定义信息直接以注解的形式定义在实现类中,从而达到了零配置的目的。

控制反转是一种通过描述(XML或注解)并通过第三方去生产或获取特定对象的方式。在Spring中实现控制反转的是IoC容器,其实现方法是依赖注入(Dependency Injection,DI)。

​ [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6da2CG78-1633929723340)()]

  1. HelloSpring

    Hello实体类

    public class Hello {
       private String name;
    
       public String getName() {
           return name;
      }
       public void setName(String name) {
           this.name = name;
      }
    
       public void show(){
           System.out.println("Hello,"+ name );
      }
    }
    
    

    beans.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd">
    
       <!--bean就是java对象 ,Spring创建和管理-->
       <bean id="hello" class="com.kuang.pojo.Hello">
           <property name="name" value="Spring"/>
       </bean>
    
    </beans>
    

    测试

    @Test
    public void test(){
       //解析beans.xml文件 , 生成管理相应的Bean对象
       ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
       //getBean : 参数即为spring配置文件中bean的id .
       Hello hello = (Hello) context.getBean("hello");
       hello.show();
    }
    

    结论

    • Hello 对象是谁创建的 ? 【hello 对象是由Spring创建的
    • Hello 对象的属性是怎么设置的 ? hello 对象的属性是由Spring容器设置的

    这个过程就叫控制反转 :

    • 控制 : 谁来控制对象的创建 , 传统应用程序的对象是由程序本身控制创建的 , 使用Spring后 , 对象是由Spring来创建的

    • 反转 : 程序本身不创建对象 , 而变成被动的接收对象 .

      依赖注入 : 就是利用set方法来进行注入的.

      IOC是一种编程思想,由主动的编程变成被动的接收

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
          xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
          xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd">
    
       <bean id="MysqlImpl" class="com.kuang.dao.impl.UserDaoMySqlImpl"/>
       <bean id="OracleImpl" class="com.kuang.dao.impl.UserDaoOracleImpl"/>
    
       <bean id="ServiceImpl" class="com.kuang.service.impl.UserServiceImpl">
           <!--注意: 这里的name并不是属性 , 而是set方法后面的那部分 , 首字母小写-->
           <!--引用另外一个bean , 不是用value 而是用 ref-->
           <property name="userDao" ref="OracleImpl"/>
       </bean>
    
    </beans>
    
    
  2. IoC创建对象

    无参构造

     <bean id="user" class="com.kuang.pojo.User">
           <property name="name" value="kuangshen"/>
       </bean>
    

    在调用show方法之前,User对象已经通过无参构造初始化了!

    有参构造

    <!-- 第一种根据index参数下标设置 -->
    <bean id="userT" class="com.kuang.pojo.UserT">
       <!-- index指构造方法 , 下标从0开始 -->
       <constructor-arg index="0" value="kuangshen2"/>
    </bean>
    <!-- 第二种根据参数名字设置 -->
    <bean id="userT" class="com.kuang.pojo.UserT">
       <!-- name指参数名 -->
       <constructor-arg name="name" value="kuangshen2"/>
    </bean>
    <!-- 第三种根据参数类型设置 -->
    <bean id="userT" class="com.kuang.pojo.UserT">
       <constructor-arg type="java.lang.String" value="kuangshen2"/>
    </bean>
    
    

    在配置文件加载的时候。其中管理的对象都已经初始化了!

    只要在配置文件的对象都被初始化

  3. Spring配置

    别名

    alias 设置别名 , 为bean设置别名 , 可以设置多个别名

    Bean的配置

SpringMVC

  1. 特点

    1. 轻量级,简单易学
    2. 高效 , 基于请求响应的MVC框架
    3. 与Spring兼容性好,无缝结合
    4. 约定优于配置
    5. 功能强大:RESTful、数据验证、格式化、本地化、主题等
    6. 简洁灵活

    Spring的web框架围绕DispatcherServlet [ 调度Servlet ] 设计。DispatcherServlet的作用是将请求分发到不同的处理器。

  2. Spring MVC框架像许多其他MVC框架一样, 以请求为驱动 , 围绕一个中心Servlet分派请求及提供其他功能**,**DispatcherServlet是一个实际的Servlet (它继承自HttpServlet 基类)。

  3. SpringMVC的原理

    当发起请求时被前置的控制器拦截到请求,根据请求参数生成代理请求,找到请求对应的实际控制器,控制器处理请求,创建数据模型,访问数据库,将模型响应给中心控制器,控制器使用模型与视图渲染视图结果,将结果返回给中心控制器,再将结果返回给请求者。

  4. 简单分析执行流程

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-46IxKkgR-1633929723342)(C:UserszgAppDataRoamingTyporatypora-user-images1633871398846.png)]

    1. DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心。用户发出请求,DispatcherServlet接收请求并拦截请求。
      我们假设请求的url为 : http://localhost:8080/SpringMVC/hello
      如上url拆分成三部分:**
    2. HandlerMapping为处理器映射。DispatcherServlet调用HandlerMapping,HandlerMapping根据请求url查找Handler。
    3. HandlerExecution表示具体的Handler,其主要作用是根据url查找控制器,如上url被查找控制器为:hello。
    4. HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等。
    5. HandlerAdapter表示处理器适配器,其按照特定的规则去执行Handler。
    6. Handler让具体的Controller执行。
    7. Controller将具体的执行信息返回给HandlerAdapter,如ModelAndView。
    8. HandlerAdapter将视图逻辑名或模型传递给DispatcherServlet。
    9. DispatcherServlet调用视图解析器(ViewResolver)来解析HandlerAdapter传递的逻辑视图名。
    10. 视图解析器将解析的逻辑视图名传给DispatcherServlet。
    11. DispatcherServlet根据视图解析器解析的视图结果,调用具体的视图。
    12. 最终视图呈现给用户。

erServlet** [ 调度Servlet ] 设计。DispatcherServlet的作用是将请求分发到不同的处理器。

  1. Spring MVC框架像许多其他MVC框架一样, 以请求为驱动 , 围绕一个中心Servlet分派请求及提供其他功能**,**DispatcherServlet是一个实际的Servlet (它继承自HttpServlet 基类)。

  2. SpringMVC的原理

    当发起请求时被前置的控制器拦截到请求,根据请求参数生成代理请求,找到请求对应的实际控制器,控制器处理请求,创建数据模型,访问数据库,将模型响应给中心控制器,控制器使用模型与视图渲染视图结果,将结果返回给中心控制器,再将结果返回给请求者。

  3. 简单分析执行流程

    [外链图片转存中…(img-46IxKkgR-1633929723342)]

    1. DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心。用户发出请求,DispatcherServlet接收请求并拦截请求。
      我们假设请求的url为 : http://localhost:8080/SpringMVC/hello
      如上url拆分成三部分:**
    2. HandlerMapping为处理器映射。DispatcherServlet调用HandlerMapping,HandlerMapping根据请求url查找Handler。
    3. HandlerExecution表示具体的Handler,其主要作用是根据url查找控制器,如上url被查找控制器为:hello。
    4. HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等。
    5. HandlerAdapter表示处理器适配器,其按照特定的规则去执行Handler。
    6. Handler让具体的Controller执行。
    7. Controller将具体的执行信息返回给HandlerAdapter,如ModelAndView。
    8. HandlerAdapter将视图逻辑名或模型传递给DispatcherServlet。
    9. DispatcherServlet调用视图解析器(ViewResolver)来解析HandlerAdapter传递的逻辑视图名。
    10. 视图解析器将解析的逻辑视图名传给DispatcherServlet。
    11. DispatcherServlet根据视图解析器解析的视图结果,调用具体的视图。
    12. 最终视图呈现给用户。

最后

以上就是闪闪奇迹为你收集整理的SSM框架SSM框架的全部内容,希望文章能够帮你解决SSM框架SSM框架所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(37)

评论列表共有 0 条评论

立即
投稿
返回
顶部