初识SpringMVC
什么是SpringMVC
Spring MVC是基于Java实现的MVC设计模式的轻量级Web框架(本质是Servlet)用于处理请求响应
为什么要学SpringMVC
Spring MVC的特点:
- 轻量级,简单易学
- 高效 , 基于请求响应的MVC框架【即处理一个请求并响应一个视图】
- 与Spring兼容性好,无缝结合【因为i它本来就是spring的一部分,我们可以将要使用到的bean全都注册到spring容器中】
- 约定优于配置【maven相同特性】
- 功能强大:RESTful(地址栏不使用?传参)、数据验证、格式化、本地化、主题等
- 最重要的一点还是用的人多 , 生态社区
- Spring的web框架围绕DispatcherServlet [ 调度Servlet ] 设计
- DispatcherServlet的作用是将请求分发到不同的处理器。从Spring 2.5开始,使用Java 5或者以上版本的用户可以采用基于注解形式进行开发,十分简洁;
- 正因为SpringMVC好 , 简单 , 便捷 , 易学 , 天生和Spring无缝集成(使用SpringIoC和Aop) , 使用约定优于配置 . 能够进行简单的junit测试 . 支持Restful风格 .异常处理 , 本地化 , 国际化 , 数据验证 , 类型转换 , 拦截器 等等…所以我们要学习 .
中心控制器DispatcherServlet
Spring MVC框架像许多其他MVC框架一样, 以请求为驱动 , 围绕一个中心Servlet分派请求及提供其他功能,DispatcherServlet实际是一个Servlet (它继承自HttpServlet 基类)
SpringMVC的原理如下图所示:
当发起请求时被前置的控制器拦截到请求,根据请求参数生成代理请求,找到请求对应的实际控制器,控制器处理请求,创建数据模型,访问数据库,将模型响应给中心控制器,控制器使用模型与视图渲染视图结果,将结果返回给中心控制器,再将结果返回给请求者
代码实践
基于配置
- 配置springMVC
<?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">
<!--1.注册DispatcherServlet-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--关联一个springmvc的配置文件:【servlet-name】-servlet.xml-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<!--启动级别-1-->
<load-on-startup>1</load-on-startup>
</servlet>
<!--/ 匹配所有的请求;(不包括.jsp)-->
<!--/* 匹配所有的请求;(包括.jsp)-->
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
- 编写springMVC-servlet的配置文件
<?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 class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<!--视图解析器:DispatcherServlet给他的ModelAndView-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" id="InternalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>
</beans>
- 编写一个controller
package com.thhh.controller;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
//注意:这里我们先导入Controller接口
public class HelloController implements Controller {
public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception {
//ModelAndView 模型和视图
ModelAndView mv = new ModelAndView();
//封装对象,放在ModelAndView中。Model
mv.addObject("msg","HelloSpringMVC!");
//封装要跳转的视图,放在ModelAndView中
mv.setViewName("hello"); //: /WEB-INF/jsp/hello.jsp
return mv;
}
}
- 添加lib
代码解析
- 首先就是我们直接去请求的URL,在原来的MVC架构中,只要你不是直接去请求WEB文件夹下的JSP页面,那么你的URL后面必然是一个在WEB.XML中注册了映射关系的servlet
- 可见我们并没有在web.XML中发现对应的URL的注册,但是我们发现了一个匹配所有请求的servlet注册
对比
- 在上面的例子中我们并没有写servlet,我们只是在web.xml文件中注册了一个拦截所有请求的spring自己自带的一个servlet——DispatcherServlet
- 上一点说明我们少写了一个servlet,少写servlet就意味着少去web.xml中注册一个servlet
但是我们多写了一个spring的配置文件springmvc-servlet.xml和一个controller程序HelloController
基于注解
代码实现
- 添加maven配置文件文件过滤配置
<build>
<resources>
<resource>
<directory>src/main/resources</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
<resource>
<directory>src/main/java</directory>
<includes>
<include>**/*.properties</include>
<include>**/*.xml</include>
</includes>
<filtering>true</filtering>
</resource>
</resources>
</build>
- 配置web.xml文件,文件内容和前面的例子一样
- 注册DispatcherServlet
- 关联spring MVC配置文件
- 设置启动级别为1
- 映射路径为/,不要使用/*
<?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">
<!--配置DispatcherServlet,它就是springMVC的核心,一般称为 请求转发器 / 前端控制器(官方推荐)
它的本质就是一个servlet,所以直接按照servlet的方式配置即可-->
<servlet>
<servlet-name>srpingmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><!--这个servlet就是spring直接写好了的,我们直接使用即可-->
<!--DispatcherServlet必须绑定spring配置文件-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<!--启动级别-->
<load-on-startup>1</load-on-startup><!--设置启动级别为1,即服务器一启动就会去加载DispatcherServlet-->
</servlet>
<servlet-mapping>
<servlet-name>srpingmvc</servlet-name>
<url-pattern>/</url-pattern>
<!--只写一个/,表示匹配所有的请求
注意区分/和/*的区别,在学习javaweb的时候匹配所有的请求我们都是使用的/*
1.在speingMVC中,/只会匹配对于servlet的请求,不会去匹配jsp页面
2./*是所有的请求都会匹配,包括jsp页面
-->
</servlet-mapping>
</web-app>
- 配置spring.xml【不同点】,现在这个配置文件配置之后再也不需要去改动了,前面的例子中,我们每写一个controller还要回到IOC容器中注册,现在直接使用注解开发,开启了component-scan,所以再也不需要修改这个配置文件了
<?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.thhh.controller"/>
<!-- 让Spring MVC不处理静态资源,像.css\.js\.html\.mp3\.mp4这些不需要动态处理的资源,我们完全没有必要走Spring MVC动态处理这一条线 -->
<mvc:default-servlet-handler />
<!--
支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入。
-->
<mvc:annotation-driven /><!--使用这个配置,将会自动为我们向IOC容器中注入HandlerMapping和HandlerAdapter两个对象,不再需要我们自己去配置-->
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!-- 前缀 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后缀 -->
<property name="suffix" value=".jsp" />
</bean>
</beans>
- 创建一个跳转页面hello.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
</body>
</html>
- 编写controller【使用注解,不手动实现接口】
package com.thhh.controller;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloController {
@RequestMapping("/hello") //设置这个controller的请求路径
public String test01(Model model){
//向模型中添加数据,可以直接在JSP页面中取出并渲染
model.addAttribute("msg","Hello,SpringMVC Annotation.");
//设置要跳转的视图名称
return "hello";
}
}
小结
-
新建一个web项目
-
导入相关jar包
-
编写web.xml,注册DispatcherServlet
-
编写springmvc配置文件,其实就是原来的spring配置文件,用于开启spring注解开发支持、过滤静态资源请求、自动装配HandlerMapping和HandlerAdapter两个对象和配置视图解析器
-
创建controller,这一步就和原来的MVC3层架构和讲解springMVC原理的时候写的controller不一样了,在实际开发中我们使用注解进行开发的时候,一个controller类不再仅仅是对应一个请求的controller类了,而是一个controller处理集合
-
设置controller返回的视图名称
-
开启tomcat测试运行
使用springMVC必须配置的三大件
处理器映射器、处理器适配器、视图解析器
使用注解开发时,我们只需要手动配置视图解析器,而处理器映射器和处理器适配器只需要开启注解驱动即可,而省去了大段的xml配置