概述
前文记录了MVC模式和Spring MVC的初步认识(前文连接:https://www.jianshu.com/p/c19732ac8f76),现在记录创建一个项目,配置Spring MVC,编写接口程序。
创建项目
打开IntelliJ IDEA,点击“File->New->Project...”,在打开的界面中左侧选择“Maven”,勾选“Create from archetype”,选中“maven-archetype-webapp”,点击“Next”:
![](https://img.haomeiwen.com/i14093025/490ee1a9c0a00246.png)
填写GroupId等信息填写完整,点击“Next”:
![](https://img.haomeiwen.com/i14093025/9fba001be34ba961.png)
配置好本机安装的maven目录,点击“Next”:
![](https://img.haomeiwen.com/i14093025/4c90bbcc4862a578.png)
设置好项目存放目录,点击“Finish”:
![](https://img.haomeiwen.com/i14093025/9b60e8a4ce0d75e4.png)
maven需要下载相应的依赖,稍后片刻,创建完成,目录结构如下:
![](https://img.haomeiwen.com/i14093025/3d8b101f2bcb4110.png)
此时目录结构是缺失的,需要进行完善,点击“File->Project Structure...”,左侧选中“Modules”,点击“Sources”:
![](https://img.haomeiwen.com/i14093025/1c49cd1573ca5371.png)
选中“main”目录,右键菜单中点击“New Folder...”,新建一个名为“java”的文件夹:
![](https://img.haomeiwen.com/i14093025/240185b876a52293.png)
选中“java”文件夹,点击上方“Sources”按钮,可以看到“java”文件夹变色,并已被标记为“Source Folders”文件夹:
![](https://img.haomeiwen.com/i14093025/70f1d815cf45e388.png)
![](https://img.haomeiwen.com/i14093025/8be4cd2c669b6099.png)
选中“main”目录,右键菜单中点击“New Folder...”,新建一个名为“resources”的文件夹:
![](https://img.haomeiwen.com/i14093025/db7f0df09ba27795.png)
选中“resources”文件夹,点击上方“Resources”按钮,可以看到“resources”文件夹标识变更,并已被标记为“Resources Folders”文件夹:
![](https://img.haomeiwen.com/i14093025/d214a24cf34edd6b.png)
选中“src”目录,右键菜单中点击“New Folder...”,新建一个名为“test”的文件夹,选中“test”目录,右键菜单中点击“New Folder...”,新建一个名为“java”的文件夹:
![](https://img.haomeiwen.com/i14093025/310464eb4ac8ef4e.png)
选中“java”文件夹,点击上方“test”按钮,可以看到“java”文件夹变色,并已被标记为“Test Source Folders”文件夹:
![](https://img.haomeiwen.com/i14093025/53abfe79ae028ccb.png)
然后创建包,选中java目录,右键“New->Package”,输入包名“com.snow.dcl.controller”,点击“确定”:
![](https://img.haomeiwen.com/i14093025/32a9844abf35c7a8.png)
至此项目目录结构就配置完整了。
配置Tomcat
Tomcat配置前文已经记录过了,此处不做重复记录(前文连接:https://www.jianshu.com/p/3cf98b5156e7)。
添加Spring MVC依赖
打开pom文件,在<dependencies>标签中添加如下依赖:
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>4.3.10.RELEASE</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
</dependency>
基于配置的控制器实例
配置前端控制器DispatcherServlet
DispatcherServlet的核心功能是分发请求,请求会被分发给对应处理的Java类,称为Handle,在Spring 2.5版本以前开发一个Handle必须实现org.springframework.web.servlet.mvc.Controller接口,Controller接口必须实现ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception方法,Controller接口的实现类可以通过该方法传递参数访问对应请求的HttpServletRequest和HttpServletResponse对象,请求处理完成后,返回一个包含模型对象和视图路径的ModelAndView对象;在Spring 2.5版本新增了可基于注解的控制器,即不需要实现Controller接口,通过注释类型来描述即可完成功能。
先不使用注解的方式进行记录,展开项目的目录结构,双击打开web.xml文件,替换为下面内容:
<?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_3_1.xsd"
version="3.1">
<display-name>Archetype Created Web Application</display-name>
<!--welcome pages-->
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
<!--配置Spring MVC DispatcherServlet-->
<servlet>
<servlet-name>springMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!--配置/WEB-INF目录下的springmvc-servlet.xml作为mvc的配置文件-->
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/springmvc-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
<async-supported>true</async-supported>
</servlet>
<!--配置Spring MVC DispatcherServlet拦截所有请求-->
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
然后配置springmvc-servlet.xml,在WEB-INF目录下右键“New->File”创建springmvc-servlet.xml,双击打开该文件,填写以下内容:
<?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">
<!--配置Handle,映射"/hello"请求-->
<bean name="/hello" class="com.snow.dcl.controller.HelloController"/>
<!--将bean的name作为url进行查找-->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"/>
</beans>
配置文件内容含义:
- 首先声明了HelloController业务控制器类,并将其映射到/hello请求。
- 配置了处理映射器BeanNameUrlHandlerMapping,以Bean的名称作为url进行查找。
- 配置了处理器适配器SimpleControllerHandlerAdapter,对HelloController类的handleRequest方法进行调用。
- 配置视图解析器InternalResourceViewResolver解析视图,将view呈现给用户。
Spring 4.0版本之后,处理映射器、处理器适配器、视图解析器不需要进行配置,Spring会提供默认配置进行使用,此处进行配置是为了理解原理。
在“com.snow.dcl.controller”包下右键“New->Java Class”,创建一个名为“HelloController”的类,编写如下代码:
public class HelloController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) {
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject("message", "Hello!");
modelAndView.setViewName("/WEB-INF/content/welcome.jsp");
return modelAndView;
}
}
HelloController是实现了Controller接口的控制器,处理请求动作;handleRequest是必须实现的方法,该方法的参数对应请求的HttpServletRequest和HttpServletResponse,必须返回一个包含视图名或视图名和模型的ModelAndView对象,此处返回的模型中包含message字符串对象,返回的视图路径/WEB-INF/content/welcome.jsp,即请求被转发到welcome.jsp。
选中WEB-INF目录,右键“New->Directory”,命名为“content”,然后同样方式在该目录中创建welcome.jsp,文件中编写如下代码:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html" charset="UTF-8">
<title>welcome</title>
</head>
<body>
${requestScope.message}
</body>
</html>
此处使用JSP的EL表达式${requestScope.message}来获取HelloController的ModelAndView对象中message的值并显示在浏览器中。
测试
启动TomcatServer,启动完成后,打开浏览器输入:http://localhost:8080/hello,访问成功。
基于注解的控制器实例
Spring 2.5版本后,增加了基于注解的控制器,即不需要实现Controller接口,通过注解即可实现功能。
修改HelloController类
打开HelloController类文件,代码修改如下:
@Controller
public class HelloController {
@RequestMapping(value = "/hello")
public ModelAndView hello() {
ModelAndView modelAndView = new ModelAndView();
modelAndView.addObject("message", "Hello!");
modelAndView.setViewName("/WEB-INF/content/welcome.jsp");
return modelAndView;
}
}
HelloController是一个基于注解的控制器,使用@Controller注解标示,@RequestMapping注解用来映射一个请求和请求的方法,value = "/hello"表示请求由hello方法进行处理,方法返回一个包含视图名或视图名和模型的ModelAndView对象。
修改Spring MVC的配置文件
打开springmvc-servlet.xml,内容修改如下:
<?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"
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">
<!--spring可以自动扫描base-package设置的包或子包下的java类,如果扫描到有spring相关注解的类,则注册为spring的bean-->
<context:component-scan base-package="com.snow.dcl.controller"/>
<!--配置annotation类型的映射处理器-->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
<!--配置annotation类型的处理器适配器-->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"/>
</beans>
Spring的扫描机制会自动扫描com.snow.dcl.controller包下使用了@Controller注解的控制器类,配置的RequestMappingHandlerMapping映射处理器处理会根据请求查找映射,配置的RequestMappingHandlerAdapter来完成对@RequestMapping注解的方法的调用,配置的InternalResourceViewResolver解析视图呈现给用户。
Spring 4.0版本之后,处理映射器、处理器适配器会有跟简单的方式进行配置,此处进行配置是为了理解原理。
测试
启动TomcatServer,启动完成后,打开浏览器输入:http://localhost:8080/hello,访问成功。