一、SpringMVC概述
1.1 MVC架构
MVC(Model View Controller) 是一种软件设计典范。主要作用是将视图展示和业务控制代码分离开来。
- Model(模型)
- 数据模型,用于封装数据
- View(视图)
- 页面视图,用于展示数据
- jsp ,html,json,xml等
- Controller(控制器)
- 处理用户交互的调度器,用于根据用户需求处理程序逻辑
- Servlet 、SpringMVC等
思考:MVC架构跟三层架构是什么关系?
可以这样理解:
1.MVC把三层架构中的web层再度进行了分化,分成了控制器、视图、模型。
2.三层架构的目的是【解耦】,mvc的目的是实现web层系统的【职责划分】。
MVC架构在三层架构中的位置图示:
1.2 SpringMVC
SpringMVC 顾名思义就是Spring对MVC架构的一种实现,属于轻量级的WEB框架。
它通过一个简单的注解就可以让一个普通的Java类成为控制器,这种低侵入性的设计使得他备受业界欢迎
同时他还支持RestFul风格的编程风格。
SpringMVC是spring对web层进行的封装,提供的MVC架构
M(模型):
Model可以叫做数据模型层,说白了就是用来封装数据的
例如:用户发送注册请求,那么请求的信息会被SpingMMVC封装到User实体类中,这个实体类就属于Model层;
用户发送查询个人信息的请求,那么后台也会将个人信息封装到一个User类型,数据同样也是Model层;
V(视图):
View说白了就是SpringMVC响应请求的一种数据展示(最终的执行结果):
例如:SpringMVC响应的数据方式:JSP、json、xml、html等
C(控制):
控制层就用来处理交互的部分,接收用户请求,然后执行业务等流程,最终反馈结果;
控制器,本质上就是一个Servlet,一切请求都访问这个Servlet,在这个Servlet中进行调度
SpringMVC可以通过一个简单的注解,就能让浏览器访问到对应的方法.
@RequestMapping("/请求路径")
总之,这个唯一的Servlet核心控制器会【根据请求的url匹配基于注解的url】,完成请求处理;
二、SpringMVC 入门【重点】
目标: 通过浏览器访问SpringMVC框架返回一个jsp页面
学习要求:
1.按照流程实现功能 ★★★
2.描述执行流程 ★★★
3.描述实现原理
服务器启动时,加载原理
浏览器访问时,执行原理
2.1 创建工程,引入坐标
创建web项目
编写pom.xml(指定工程war打包方式)
<?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.itheima</groupId>
<artifactId>day04_springmvc_01</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<!-- 导入jar包依赖 -->
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.2.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
</project>
2.2 配置核心Servlet
编写web.xml文件
在web.xml文件中配置核心控制器
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">
<!--
服务器启动时只会加载web项目的核心配置文件 web.xml
-->
<!-- 配置SpringMVC的核心Servlet: 前端控制器 (由SpringMVC框架提供)-->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置SpringMVC的核心配置文件 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<!-- 我们给前端控制器配置的路径为 / (缺省匹配)可以匹配浏览器发送的所以请求
注意: jsp除外
-->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
2.3 编写SpringMVC配置文件
spring-mvc.xml约束头
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 开启包扫描 -->
<context:component-scan base-package="com.itheima"></context:component-scan>
<!-- 配置视图解析器: 生成前缀和后缀 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 将可能使用到的处理器适配器,处理器映射器,视图解析器统统的加载到内存中 -->
<mvc:annotation-driven/>
</beans>
2.4 编写业务处理器
package com.itheima.web;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* 编写处理器方法
*/
@Controller
public class HelloController {
/**
* @RequestMapping :
* 作用: 建立请求路径与此方法的对应关系
* @return
*/
@RequestMapping("/hello")
public String hello(){
System.out.println("hello springmvc....");
// 如果直接返回字符串,则代表请求转发
return "success";
}
}
2.5 编写响应页面
在Webapp/pages/ 下定义success.jsp
success.jsp响应页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>执行成功...</h1>
</body>
</html>
2.6 Tomcat插件的使用
开发中,直接使用tomcat会有繁琐的配置,我们可以使用maven支持的tomcat插件,提高开发效率;
直接在pom文件中添加tomcat插件:
<build>
<plugins>
<!-- tomcat7插件,运行命令: mvn tomcat7:run -DskipTests -->
<!-- 配置Tomcat插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<uriEncoding>UTF-8</uriEncoding>
<port>8080</port>
<path>/</path>
</configuration>
</plugin>
<!--<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.1</version>
<configuration>
<source>8</source>
<target>8</target>
</configuration>
</plugin>-->
</plugins>
</build>
三、核心原理分析【能说】
3.1 入门案例执行过程
【1】启动初始化顺序
资源准备阶段:
(1