一,配置方式
学习之前先按照如下方式创建一个简单的springmvc项目,参照项目信息进行学习。文中所用到的开发工具为Idea.
- 创建一个空的pom工程,新建一个Moudle ,如 springmvc-01-hello , 完成后选择已创建的Moudle鼠标右击选Add Frameworks Support添加web的支持
- 在pom.xml中添加SpringMVC和servlet 依赖
<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>
- 配置web.xml , 注册DispatcherServlet
<?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>
- 在resoueces编写SpringMVC 的 配置文件!如名称:springmvc-servlet.xml 需同web.xml中配置的中classpath值相同
<?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>
- 写Contoroller,使用ModelAndView封装数据和视图对象
package com.leshangju.springmvc;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class HelloController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
//ModelAndView 模型和视图
ModelAndView mv = new ModelAndView();
//封装对象,放在ModelAndView中
mv.addObject("msg", "HelloSpringMVC!");
//封装要跳转的视图,放在ModelAndView中
mv.setViewName("hello"); //: /WEB-INF/jsp/hello.jsp
return mv;
}
}
- 将Controller交给SpringIOC容器管理(在springmvc-servlet.xml中注册Bean)
<!--注册bean-->
<bean id="/hello" class="com.kuang.controller.HelloController"/>
- 编写前端视图页面
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Kuangshen</title>
</head>
<body>
${msg}
</body>
</html>
- 发布项目,启动Tomcat后,在浏览器输入localhost:8080/hello访问页面
注意,如遇到404错误,先排查代码和配置有没有一楼,如果没有,则查看打成的包结构中WEB-INF下有没有lib依赖文件夹,如果没有按照如下步骤手动新建lib包并将依赖jar包添加,然后重新打包并发布即可
- 注解方式分析SpringMVC执行流程
(上图中只有黄色部分是需要开发人员去开发的,其余均由springmvc根据配置信息完成)
以上流程图的具体执行步骤为:
1.客户端发起请求,如http://localhost:8080/hello给WEB服务器,以上URL可以表示为请求在localhost:8080服务器上/站点下的hello控制器,请求被Spring 前端控制器DispatcherServlet捕获(调用了doService()方法)。
2.DispatcherServlet请求HandlerMapping(可以根据xml配置、注解进行查找)如xml中配置的为(BeanNameUrlHandlerMapping)
3.HandlerMapping向DispatcherServlet返回具体Handler,HandlerMapping会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器(页面控制器)对象,多个HandlerInterceptor拦截器对象)
4.DispatcherServlet请求HandlerAdapter适配器(XML中配置的SimpleControllerHandlerAdapter),并将要执行的Handler信息发送给HandlerAdapter(com.leshangju.springmvc.HelloController,和携带的参数)
5.AdapterHandler收到请求后会检查该请求有没有配置拦截器,如果有,则先执行拦截器的preHandler()方法,如果没有则进行第6步
6.AdapterHandler提取Request中的模型数据,填充Handler入参,并发送给Handler(Controller)执行。 在填充Handler的入参过程中,spring根据配置信息还会做一下操作:
- HttpMessageConveter: 将请求消息(如Json、xml等数据)转换成一个对象,将对象转换为指定的响应信息
- 数据转换:对请求消息进行数据转换。如String转换成Integer、Double等
- 数据根式化:对请求消息进行数据格式化。 如将字符串转换成格式化数字或格式化日期等
- 数据验证: 验证数据的有效性(长度、格式等),验证结果存储到BindingResult或Error中7
7.Handler(Contollorer)调用具体的业务层实现,并封装成ModelAndView对象(包含模型数据msg、逻辑视图名hello)
8.Handler(Contollorer)将封装好的ModelAndView(模型数据msg、逻辑视图名hello)返给AdapterHandler
9.AdapterHandler将ModelAndView(模型数据msg、逻辑视图名hello)转发给DispatcherServlet
10.DispatcherServlet请求ViewReslover视图解析器(xml中配置的是InternalResourceViewResolver)
11.ViewResolver根据逻辑视图名解析成真正的视图(/WEB-INF/jsp/hello.jsp)View实例,并返还给DispatcherServlet。(接口ViewResolver里面有一个方法:resolveViewName,可以根据逻辑视图名viewName返回一个View实例,此时的View实例只是一个静态资源,没有数据填充)。
12.DispatcherServlet将模型数据model(此实例ModelAndView中的模型数据msg)填充至view中,完成对View实例渲染
13.用户界面呈现
二,注解方式(推荐)
-
创建一个空的pom工程,新建一个Moudle ,如 springmvc-03-annotation, 完成后选择已创建的Moudle鼠标右击选Add Frameworks Support添加web的支持
-
在pom.xml中添加SpringMVC和servlet 依赖,同第一种方式中的依赖信息
-
在web.xml中配置DispatcherServlet
-
在项目recourse下面创建配置spring中的配置文件,文件名同web.xml中配置的名字一样
-
创建注解形式的Controller
package com.leshangju.springmvc;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloAnnotation {
@RequestMapping("/hello")
public String hello(Model model) {
model.addAttribute("msg", "Hello,SpringMVC Annotation");
return "hello";
}
}
-
创建视图页面
-
启动tomcat访问页面
注意:
@Contoller只能返回视图
@RestContoller可以返回json数据,不会被视图解析器解析
@RequestMapping映射URL到特定的映射器类或者特定的处理程序方法