1. SpringMVC
1.1 引言
1.1.1 什么是SpringMVC?
- SpringMVC是一种基于 Java 的实现MVC设计模型的请求驱动类型的轻量级Web框架,属于Spring框架的一个模块。
- 它通过一套注解,让一个简单的Java类成为处理请求的控制器,而无须实现任何接口。同时它还支持RESTful编程风格的请求
1.1.2 SpringMVC的执行流程?
- 客户端发送请求request,前端控制器(DispatcherServlet)接收请求
- 前端控制器请求处理器映射器(HandlerMapping)查找Handler,依据注解和xml配置查找
- 处理器映射器返回查找到的Handler给前端控制器
- 前端控制器请求处理器适配器(HandlerAdapter)执行Handler(通常称为Controller)
- 处理器适配器执行Handler处理器
- Handler处理器执行完毕以后返回给处理器适配器一个ModelAndView对象。(包含数据模型和视图名称)
- 处理器适配器把这把ModelAndView返回给前端控制器
- 前端控制器接收到ModelAndView后请求视图解析器(ViewResolver),对视图解析解析
- 视图解析器通过View的信息匹配到相应的视图结果,返回给前端控制器
- 前端控制器接收视图结果,并进行视图渲染,就是把Model模型数据填充到View视图的request作用域中, 生成最终的视图
- 最后把视图返回给客户端
1.2 MVC架构
1.2.1 什么是MVC模式?
把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller)
- Model(模型):业务模型,负责在数据库中存取数据,对应项目只读service和dao
- View(视图):渲染数据,生成页面,是应用程序中处理数据显示的部分。对应项目中的Jsp
- Controller(控制器):控制MVC流程,接收用户在View层的输入,调用Model层获取数据,填充给View层。对应项目中的Servlet
通常控制器负责从视图读取用户输入的数据,然后从模型中请求数据,并将其交给视图
2. 开发流程
先新建web项目,并部署tomcat:SpringMVC项目新建
2.1 导入SpringMVC的依赖
新建maven项目,在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>org.example</groupId>
<artifactId>springMVC01</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.16</version>
</dependency>
</dependencies>
</project>
spring-webmvc就是springMVC的核心依赖,导入它之后会自动导入其他的依赖,如图
为什么会自动这些导入依赖?
springMVC是spring的一个模块,当这个模块在运行时呢,需要一些其他模块的支持,所有会额外导入其他的相关的jar包
2.2 配置前端控制器
前端控制器就是接收客户端请求
main目录下新建webapp–>WEB-INF–>web.xml(web.xml不用自己新建,点击File,选中Project Structure,选中Modules,选中Web,点击+,改一下路径,存到刚刚新建的webapp–>WEB-INF下面
<?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-name>mvc_xmq</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--Servlet启动时刻,饿汉式和懒汉式,不加这行代码默认懒汉式-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>mvc_xmq</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
2.3 后端控制器
相当于Servlet
- com.lyx.web.HelloController创建HelloController.java类
@Controller //声明这是一个控制器
@RequestMapping("/hello") //设置访问路径
public class HelloController{
@RequestMapping("/test1")//设置方法的访问路径
public String hello1(){
System.out.println("hello world1!");
return null;
}
@RequestMapping("/test2")//设置方法的访问路径
public String hello2(){
System.out.println("hello world2!");
return null;
}
}
2.4.1 @RequestMapping()注解
- 对添加的注解,要在mvc.xml配置注解扫描和注解驱动
- resources目录下新建mvc.xml文件,注解扫描如下
<?xml version="1.0" encoding="UTF8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd"
>
<context:component-scan base-package="com.lyx"/>
<mvc:annotation-driven></mvc:annotation-driven>
</beans>
现在回到注解@RequestMapping
上图可以看到注解有method和params属性
下面来解释:先写一个jsp页面用于请求
看到form表单请求方式是post,请求路径为@RequestMapping定义的(/test/hello)
上图中看到@RequestMapping的method方法的返回值为RequestMethod类型的数组,该RequestMethod类型是枚举类型,有get post put delete等
- 所以我们通过method去指定请求方式,下面指定只接受post请求
为@RequestMapping注解添加params
设置请求路径中name值的情况,
“username”表示请求路径中必须有username参数
“age!=23”表示请求路径中必须有age参数,且不等于23
“!sex”表示请求路径中不能有sex参数
当前请求是form表单提交的数据如下
最后看看header,可以配置请求的响应头信息
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller
@RequestMapping("/test")
public class myController {
@RequestMapping(value = "/hello1", params = {"username", "age!=23", "!sex"})
public String Hello() {
System.out.println("hello1");
return "index";
}
@RequestMapping(value = "/hello2", method = RequestMethod.POST)
public String Hello2() {
System.out.println("hello2");
return "index";
}
@RequestMapping(value = "/hello3", headers = {"accept=text/css,*/*;q=0.1",
"accept-encoding=gzip, deflate, br",
"accept-language=zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6"})
public String Hello3() {
System.out.println("hello3");
return "index";
}
}
2.4 完善前端控制器的配置
- 添加init-param标签,指定要读取的mvc.xml,读取mvc.xml会读取上面添加的到注解驱动和注解扫描下的包,就会把包下的后端控制器HelloController.java文件创建并放到SpringMVC的工厂中。
- 如果省略不写:(当前SpringMVC配置文件为resource下mvc.xml)
- 如果不写init-param,配置文件就必须在WEB-INF目录下:且名称必须为servlet-name标签的value加上-servlet.xml。由于我的servlet-name的value值为mvc_lyx,所以配置文件为:mvc_lyx-servlet.xml
2. 5 Tomcat运行
- 添加Tomcat
- 配置好Tomcat后运行如下
2.6 访问跳转
后端控制器的HelloController.java文件的方法一开始返回是空值,现在我们实现跳转
@Controller
@RequestMapping("/hello")
public class HelloController {
@RequestMapping("test1")
public String hello1() {
System.out.println("hello1");
return "hello";//跳转到hello.jsp,怎么从hello变成hello.jsp呢,需要在mvc.xml文件中配置视图解析器ViewResolver
}
@RequestMapping("test2")
public String hello2() {
System.out.println("hello2");
return null;
}
}
2.6.1 补充:视图解析器InternalResourceViewResolver
<?xml version="1.0" encoding="UTF8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
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
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd"
>
<!--注解扫描-->
<context:component-scan base-package="com.lyx"/>
<!--注解驱动-->
<mvc:annotation-driven></mvc:annotation-driven>
<!--视图解析器
作用:1. 捕获后端控制器的返回值=“index”
2. 解析:在返回值的前后拼接 ==> “/index.jsp"-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--前端-->
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
视图解析器类型 | 描述 |
---|---|
BeanNameViewResolver | 将视图解析后,映射成一个bean,视图的名字就是bean的id。 |
lnternalResourceViewResolver | 将视图解析后,映射成一个资源文件。例如将一个视图名为字符串“success.jsp”的视图解析后,映射成一个名为success 的JSP文件。 |
JasperReportsViewResolver | 将视图解析后,映射成一个报表文件。 |
FreeMarkerViewResolver | 将视图解析后,映射成一个FreeMarker模板文件。FreeMarker是一款模板引擎 |
VelocityViewResolver | 将视图解析后,映射成一个Velocity模板文 |
VelocityLayoutViewResolver | 将视图解析后,映射成一个Velocity模板文 |