Spring学习之Spring MVC 初探

来源:互联网 发布:安广网络电视 编辑:程序博客网 时间:2024/06/07 01:17

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声明为控制器// 用于处理对应的请求@Controllerpublic 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就可以看到如下内容了
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,用于将方法的返回内容标注为数据(默认返回的内容会经由视图解析器进行解析),也就是说,方法返回的内容不会被当成视图进行解析,而是当成纯粹的数据进行处理,比如在上面的方法中加上该注解,则运行结果如下所示返回index
    可以看到,index直接被当成数据返回而不是视图名称,这种方式可以用于返回纯数据,也就是可以将该方法直接标注为接口,返回的数据可以是JSON(只需要将对象转为JSON格式即可)

总结

本小节主要学习了Spring MVC的基本配置以及一些常用的注解配置,关于Spring MVC还有一些内容没有学习到,将在后面继续学习。

原创粉丝点击