一、什么是MVC
data:image/s3,"s3://crabby-images/383ce/383ce6eb24e7b7ceb182a439b8470f4a611e2423" alt=""
二、什么是SpringMVC
三、SpringMVC的特点
data:image/s3,"s3://crabby-images/47e9c/47e9c367bcc07ec7cfa96611895256452118b4f4" alt=""
四、配置SpringMVC
data:image/s3,"s3://crabby-images/427af/427afdbd2be448e21b53b690711cff230c6c6e35" alt=""
简单流程:
data:image/s3,"s3://crabby-images/35418/35418393cceef3e3523a54ad9847a9ac3502cd2a" alt=""
总体框架
data:image/s3,"s3://crabby-images/2d254/2d254736b27cf929f6ffbcea7985085581865ebb" alt=""
1.创建pom.xml依赖
data:image/s3,"s3://crabby-images/c9a5f/c9a5fbc3fc244addba3ee5d6138f70187b3c9ab3" alt=""
XML
<!--打包方式-->
<packaging>war</packaging>
<!--依赖-->
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>6.1.4</version>
</dependency>
<!--servlet依赖-->
<dependency>
<groupId>jakarta.servlet</groupId>
<artifactId>jakarta.servlet-api</artifactId>
<version>6.0.0</version>
<scope>provided</scope>
</dependency>
<!--日志依赖-->
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.11</version>
</dependency>
<dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring6</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
</dependencies>
2.配置web.xml
data:image/s3,"s3://crabby-images/c3758/c3758e2afd2856fdbd91c9b5df88fd8ef8bcc42a" alt=""
XML
<!--配置springmvc的前端控制器,对浏览器发送的请求统一处理-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
3.编写控制类
就是先创建一个简单的FirstController类:
4.配置Spring MVC框架的配置文件
这个配置文件的名字为web.xml中servelet定义的名字加-servlet.xml
data:image/s3,"s3://crabby-images/f67de/f67de3452d22d1ef0edb035d2fc831042a9b6ae2" alt=""
XML
<context:component-scan base-package="com.pon.control"></context:component-scan>
<!--视图解析器-->
<bean id="thymeleafViewResolver" class="org.thymeleaf.spring6.view.ThymeleafViewResolver">
<!--作用于视图渲染的过程中,可以设置视图渲染后输出时采用的编码字符集-->
<property name="characterEncoding" value="UTF-8"/>
<!--如果配置多个视图解析器,它来决定优先使用哪个视图解析器,它的值越小优先级越高-->
<property name="order" value="1"/>
<!--当 ThymeleafViewResolver 渲染模板时,会使用该模板引擎来解析、编译和渲染模板-->
<property name="templateEngine">
<bean class="org.thymeleaf.spring6.SpringTemplateEngine">
<!--用于指定 Thymeleaf 模板引擎使用的模板解析器。模板解析器负责根据模板位置、模板资源名称、文件编码等信息,加载模板并对其进行解析-->
<property name="templateResolver">
<bean class="org.thymeleaf.spring6.templateresolver.SpringResourceTemplateResolver">
<!--设置模板文件的位置(前缀)-->
<property name="prefix" value="/WEB-INF/templates/"/>
<!--设置模板文件后缀(后缀),Thymeleaf文件扩展名不一定是html,也可以是其他,例如txt,大部分都是html,一般情况下后缀名为.html-->
<property name="suffix" value=".thymeleaf"/>
<!--设置模板类型,例如:HTML,TEXT,JAVASCRIPT,CSS等-->
<property name="templateMode" value="HTML"/>
<!--用于模板文件在读取和解析过程中采用的编码字符集-->
<property name="characterEncoding" value="UTF-8"/>
</bean>
</property>
</bean>
</property>
</bean>
5.将FirstController类进行具体编码
java
package com.pon.control;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class FirstController {
@RequestMapping(value = "/test")
public String hehe(){
return "first";//返回值代表逻辑视图的名称
}
}
6.提供浏览器显示的视图
html
<!doctype html>
<html lang="en">
<head>
<title>First Spring MVC</title>
</head>
<body>
<h1>First Spring MVC!</h1>
</body>
</html>
7.运行结果
data:image/s3,"s3://crabby-images/a5b44/a5b44702145daaaa57ef8d48e7d4ccdd0074f590" alt=""
data:image/s3,"s3://crabby-images/519e0/519e0f8d80d480e6e7544c61fc46c03103b8591e" alt=""
五、超链接
FirstController类:
java
package com.pon.control;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class FirstController {
@RequestMapping(value = "/test")
public String hehe(){
return "first";
}
@RequestMapping(value = "/aaa")//地址
public String hihi(){
return "other";
}
}
first.thymeleaf:编写浏览器看到的界面
html
<!doctype html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<title>First Spring MVC</title>
</head>
<body>
<h1>First Spring MVC!</h1> //a:超链接
<a th:href="@{/aaa}">hihi</a> //@{}这个是thymeleaf的模式
</body>
</html>
bother.thymeleaf:
html
<!doctype html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
<title>First Spring MVC</title>
</head>
<body>
<h1>你好</h1>
</body>
</html>
data:image/s3,"s3://crabby-images/fc05c/fc05c64d29a205f427c8c12800c612753298174a" alt=""
data:image/s3,"s3://crabby-images/a7b9b/a7b9b3b960a0c6e47f13be8960df5da414d24809" alt=""
六、SpringMVC配置文件
SpringMVC配置文件的名字和位置可以自定义。
data:image/s3,"s3://crabby-images/14268/142681e3926e35ae2de9382cf6e418db4ad59913" alt=""