SpringMVC复习笔记 2021-9-13

MVC

model 模型 , view 视图 , Controller 控制器
主要作用是为了降低耦合度
Model:提供要展示的数据,包含了数据层(dao)和服务层(service)
View:负责进行模型的展示,一般就是用户看的的界面..
Controller:接收用户的请求,委托给模型进行处理,然后在返回给视图


职责分析

Controller:控制器
1.获取表单的数据
2.调用业务逻辑
3.转向指定的页面
Model:模型
1.业务逻辑
2.保存数据的状态
View:视图
1.展示页面


SpringMVC

是SpringFramework的一部分,基于Java实现的MVC的轻量级Web框架
官方文档地址:https://docs.spring.io/spring-framework/docs/5.2.0.RELEASE/spring-framework-reference/web.html#spring-web

中心控制器

Spring的web框架围绕着DispathcherServlet设计,而DispathcherServlet的作用是将请求分发到不同的处理器,后面的版本都是基于注解来开发的
SpringMVC框架以请求为驱动,围绕一个Servlet分派请求及提供其他的功能

SpringMVC的执行原理

image


执行的流程

1.DispatcherServlet表示前置控制器,是整个SpringMVC的控制中心。用户发出请求,DispatcherServlet接收请求并拦截请求。
假设请求的url为 : http://localhost:8080/SpringMVC/hello
如上url拆分成三部分:
http://localhost:8080 服务器域名
SpringMVC 部署在服务器上的web站点
hello 表示控制器
如上url表示为:请求位于服务器localhost:8080上的SpringMVC站点的hello控制器。

2.HandlerMapping为处理器映射。DispatcherServlet调用HandlerMapping,HandlerMapping根据请求url查找.HandlerHandlerExecution表示具体的Handler,其主要作用是根据url查找控制器,如上url被查找控制器为:hello。HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等。

3.HandlerAdapter表示处理器适配器,其按照特定的规则去执行Handler。

4.Handler让具体的Controller执行。

5.Controller将具体的执行信息返回给HandlerAdapter,如mv。

6.HandlerAdapter将视图逻辑名或模型传递给DispatcherServlet。

7.DispatcherServlet调用视图解析器(ViewResolver)来解析HandlerAdapter传递的逻辑视图名。

8.视图解析器将解析的逻辑视图名传给DispatcherServlet。

9.DispatcherServlet根据视图解析器解析的视图结果,调用具体的视图。
最终视图呈现给用户。\


用注解实现MVC程序

1.新建一个maven项目,然后给添加web支持
2.在pom.xml中引入相关的依赖:

<dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.1.9.RELEASE</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet.jsp</groupId>
            <artifactId>jsp-api</artifactId>
            <version>2.2</version>
        </dependency>
        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>
    </dependencies>

3.配置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">
	<!--注册servlet-->
    <servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
	<!--通过初始化参数指定SpringMVC配置文件的位置,用来关联-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-servlet.xml</param-value>
        </init-param>
	<!--启动顺序,数字越小,启动的越早-->
        <load-on-startup>1</load-on-startup>
    </servlet>
		<!--springmvc会拦截所有的请求-->
    <servlet-mapping>
        <servlet-name>springmvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>
</web-app>

4.添加SpringMVC的配置文件:上述web.xml中指定的classpath:xxx

<?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">

   <!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 -->
   <context:component-scan base-package="com.sli.controller"/>
   <!-- 让Spring MVC不处理静态资源 例如.css .js 等等-->
   <mvc:default-servlet-handler />
   <!--
   支持mvc注解驱动
       在spring中一般采用@RequestMapping注解来完成映射关系
       要想使@RequestMapping注解生效
       必须向上下文中注册DefaultAnnotationHandlerMapping
       和一个AnnotationMethodHandlerAdapter实例
       这两个实例分别在类级别和方法级别处理。
       而annotation-driven配置帮助我们自动完成上述两个实例的注入。
    -->
   <mvc:annotation-driven />

   <!-- 视图解析器 -->
   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
         id="internalResourceViewResolver">
       <!-- 前缀 -->
       <property name="prefix" value="/WEB-INF/jsp/" />
       <!-- 后缀 -->
       <property name="suffix" value=".jsp" />
   </bean>

</beans>

5.创建Controller类

package com.sli.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
@RequestMapping("/qwq")
public class HelloController {

   //真实的访问地址 : 项目名/qwq/hello
   @RequestMapping("/hello")
   public String sayHello(Model model){
       //向模型中添加属性msg与值,可以在JSP页面中取出并渲染
       model.addAttribute("msg","hello,SpringMVC");
       // 在视图解析器中拼接了Web-Inf/jsp/hello.jsp
       return "hello";
  }
}

6.创建视图层

<%@ page contentType="text/html;charset=UTF-8" language="java"%>
<html>
<head>
   <title>SpringMVC</title
</head>
<body>
${msg}
</body>
</html>

7.配置Tomcat服务器,开启服务器,然后访问请求路径

注意

使用springMVC时候必须配置:
处理器映射器在web.xml

<servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-servlet.xml</param-value>
        </init-param>

        <load-on-startup>1</load-on-startup>
    </servlet>

处理器适配器(开启注解驱动即可)在springmvc-servlet中
视图解析器(开启注解驱动即可)

<!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 -->
   <context:component-scan base-package="com.sli.controller"/>
   <!-- 让Spring MVC不处理静态资源 例如.css .js 等等-->
   <mvc:default-servlet-handler />
   <!--
   支持mvc注解驱动
       在spring中一般采用@RequestMapping注解来完成映射关系
       要想使@RequestMapping注解生效
       必须向上下文中注册DefaultAnnotationHandlerMapping
       和一个AnnotationMethodHandlerAdapter实例
       这两个实例分别在类级别和方法级别处理。
       而annotation-driven配置帮助我们自动完成上述两个实例的注入。
    -->
   <mvc:annotation-driven />
posted @ 2021-09-13 18:36  1_f  阅读(23)  评论(0)    收藏  举报