Spring学习之Spring MVC 初探
前言
MVC模式,是现代开发中一种比较常见的模式,主要的作用在于将视图与控制逻辑、数据等进行分离,分离的主要目的自然是为了解耦,试想一下,如果在一个JSP页面中夹杂了JDBC代码,事务处理代码,逻辑控制代码,这样的页面是何等的混乱维护起来的难度也是非常之大。MVC模式正是将者三者进行解耦,将整体分为控制层Controller(通常由Servlet来负责),视图层View(通常由JSP或者FreeMaker等模板技术负责),数据层Model(通常有Java对象及其相应的操作负责),这样,这三者之间各司其职,控制层负责控制整体的逻辑,数据模型层负责对数据进行处理,视图层在控制层的控制下对数据模型层的产生的数据进行渲染,形成对应的视图。
Spring MVC简介
在Web开发过程中,Web的MVC模式与一般的MVC模式有点差别,主要是由于Web一般是采用HTTP协议进行交互,而HTTP协议的一个最大特点就是基于请求-响应模式,也就是说,只有当有请求的时候,才能对其进行相应,换句话说,如果用户没有请求数据,则服务器是没有办法将数据传输过去的。所以在Web中,MVC模式中的各个层次之间的交互一般都是由控制层进行处理,控制层响应客户端的请求,分析请求的内容,控制模型层产生数据,控制视图层渲染数据,并且将渲染后的结果返回给客户端。
在Spring MVC出现之前,出现了Struts等一系列优秀的MVC框架,不过,由于Spring MVC与Spring的无缝整合,加上Spring社区的推动,现在Spring MVC在Web开发中的地位越来越高,甚至于超越了Struts,而且,从Spring MVC 3.0之后,Spring MVC 提供了基于注解的处理方式,使得开发效率更加高了。
Spring MVC 小案例
动手永远都是学习编程的最佳方式,接下来通过一个小案例来学习Spring MVC。
Spring MVC的配置方式是比较简单的,主要包括在容器中注册Spring MVC,也就是在web.xml文件中配置Spring MVC的前端控制器,主要用于在Web容器启动时启动Spring MVC容器,具体的配置方式如下所示
web.xml
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
version="3.0">
<!--配置前端控制器DispatcherServlet-->
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<!--加载类路径下的Spring MVC配置文件-->
<param-value>classpath*:/spring-mvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<!--拦截对应的请求,/表示所有的请求-->
<url-pattern>/</url-pattern>
</servlet-mapping>
<context-param>
<param-name>contextConfigLocation</param-name>
<!--加载Spring的配置文件,当容器启动之后,根据配置文件的内容,完成Bean的创建等一系列的操作-->
<param-value>classpath*:/spring-config/*.xml</param-value>
</context-param>
<listener>
<!--监听Web容器的启动,用于在MVC容器中获得父容器,也就是Spring容器的信息-->
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
</web-app>
spring-mvc.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"
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
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="cn.xuhuanfeng.springweb.controller"/>
<!--开启注解驱动,简化配置-->
<mvc:annotation-driven/>
<!--启动默认的Servlet映射器,用于处理静态资源-->
<mvc:default-servlet-handler/>
<!--配置视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" >
<property name="prefix" value="/WEB-INF/views/" />
<property name="suffix" value=".jsp"/>
</bean>
<!--文件上传解析器,需要添加Apache common fileUpload依赖-->
<bean name="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="4096000"/>
<property name="maxInMemorySize" value="20000"/>
</bean>
</beans>
如上所示,简单的Spring整合Spring MVC配置文件就完成了,由于Spring MVC的默认配置基本上满足我们的需求,所以在一般情况下不需要对其做过多的修改。
接下来就可以开始动手编写对应的控制器了
// 将CommonController声明为控制器
// 用于处理对应的请求
@Controller
public class CommonController {
// 配置对应的访问路径
// 当访问 部署路径/hello就会到该方法中
@RequestMapping("/hello")
public String hello(){
// 返回对应的视图名称
// 根据前面配置的视图解析器可以知道,此时
// 对应的视图的全路径为 /WEB-INF/views/index.jsp
return "index";
}
}
创建对应的视图index.jsp如下所示
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Hello World</title>
</head>
<body>
<h2>Hello World</h2>
</body>
</html>
当所需要的依赖导入完成,将项目进行部署之后,返回部署路径/hello就可以看到如下内容了
这样一个最简单的Spring MVC就配置完成了。
Spring MVC常用配置
Spring MVC提供了非常丰富的注解配置,但是常用的注解并不是很多,具体如下
-
@Controller
主要用于将一个普通的Java类声明为控制器,负责处理用户的请求 -
@RequestMapping
主要用于标注对应的请求路径- 该注解可以用于标注类和方法,如果标注类,则该类下的所有方法的访问均在类的路径之下,比如上面,如果在类上面标注
@RequestMapping("/index")
则Hello的访问路径应该为index/hello
而不再是/hello
- RequestMapping如其名所示,是将请求与对应的控制方法进行映射,那么,在一个Http请求中,所有内容,如请求方法,请求头等信息,也是可以进行配置的,比如
@RequestMapping( value = "/hello", method = RequestMethod.GET)
,具体的可以根据需要进行配置
- 该注解可以用于标注类和方法,如果标注类,则该类下的所有方法的访问均在类的路径之下,比如上面,如果在类上面标注
-
@ResponseBody
,用于将方法的返回内容标注为数据(默认返回的内容会经由视图解析器进行解析),也就是说,方法返回的内容不会被当成视图进行解析,而是当成纯粹的数据进行处理,比如在上面的方法中加上该注解,则运行结果如下所示
总结
本小节主要学习了Spring MVC的基本配置以及一些常用的注解配置,关于Spring MVC还有一些内容没有学习到,将在后面继续学习。