如何理解SpringMVC

目录
  • 一、SpringMVC简介
  • 二、SpringMVC核心组件
    • 2.1、DispatcherServlet
    • 2.2、HandlerMapping
    • 2.3、HandlerInterceptor
    • 2.4、HandlerExecutionChain
    • 2.5、HandlerAdapter
    • 2.6、Handler
    • 2.7、ModelAndView
    • 2.8、ViewResolver
    • 2.9、View
  • 三、配置Maven环境变量
    • 3.1、Maven介绍
    • 3.2、Maven下载安装
      • 3.2.1、Maven下载
      • 3.2.2、配置环境变量
      • 3.2.3、配置Maven配置文件(本地仓库路径、镜像)
      • 3.2.4、用Maven创建项目

一、SpringMVC简介

MVC是我们开发WEB应用程序的通用架构方式

MVC的核心思想是业务数据抽取和业务数据呈现相分离。

MVC:M(Model)+V(View)+C(Controller)

M(模型层):业务数据的信息表示,通常是业务实体

V(视图层):为用户呈现数据的页面

C(控制层):调用业务逻辑产生合适的数据(Model),同时传递数据(Model)给视图层(View)呈现给用户

MVC:是一种架构模式,将业务逻辑和页面展示分离,使程序分层、分工合作,既相互独立,又协同合作。

二、SpringMVC核心组件

2.1、DispatcherServlet

前端控制器,核心

作用:接收请求,响应结果,相当于转发器,中央处理器,降低了组件之间的耦合性。

用户发送请求交给DispatcherServlet,DispatcherServlet是整个流程控制的中心,由它调用其他组件处理用户请求,分发到具体的对应Controller,从而获取到需要的业务数据Model,Model再通过DispatcherServlet传递给View完成页面呈现;DispatcherServlet的存在降低了组件的之间的耦合性。

2.2、HandlerMapping

处理器映射器

作用:根据请求的URL,找到对应的Handler,帮助DispatcherServlet找到对应的Controller

HandlerMapping负责根据用户请求找到Handler即处理器,SpringMVC提供了多种不同的映射器实现不同的映射方式,例如:配置文件方式,实现接口方式,注解方式等。

2.3、HandlerInterceptor

Handler执行前后拦截器

HandlerInterceptor是个接口,里面包含三个方法:preHandle、postHandle、afterCompletion

分别在Handler执行前、执行中、执行完成后执行的三个方法

2.4、HandlerExecutionChain

HandlerMapping返回给DispatcherServlet的执行链

HandlerMapping返回给DispatcherServlet的不光有Handler,还有HandlerInterceptor

preHandle——>ControllerMethod——>postHandle——>afterCompletion

这个链如何实现的呢?使用了Java的反射机制reflection

2.5、HandlerAdapter

处理器适配器

作用:将各种Controller适配成DispatcherServlet可以使用的Handler,通过特定规则(HandlerAdapter要求的规则)去执行Handler

通过HandlerAdapter对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。

2.6、Handler

处理器(需要工程师开发)

注意:编写Handler时需要HandlerAdapter的要求去做,这样HandlerAdapter才可以正确执行Handler

Handler是继DispatcherServlet前端控制器的后台控制器,在DispatcherServlet控制下对用户请求进行处理,Handler涉及业务需求,所以需要工程师针对用户需求进行开发,最终返回业务数据

2.7、ModelAndView

SpringMVC中对Model的一种表示形式

SpringMVC中有Model、Map,但是SpringMVC都会将其转化为ModelAndView,Model、Map都是ModelAndView的具体表现

2.8、ViewResolver

视图解析器

作用:进行视图解析,根据逻辑视图名解析成真正的视图View

ViewResolver负责将处理结果生成View视图,ViewResolver首先根据逻辑视图名解析成具体的页面地址,然后对View进行渲染,将处理结果通过页面展示给用户;SpringMVC提供了很多类型View视图,包括:jstlView、freemarkerView、pdfView、jsp、html等。

2.9、View

视图(需要工程师开发jsp、html)

View是一个接口,实现类支持不同的类型(jsp、html、freemarker、pdf等)

三、配置Maven环境变量

3.1、Maven介绍

pom:pom.xml配置文件,通过配置完成依赖关系

DependencyManagement:通过<dependencies><dependency></dependency></dependencies>节点配置

3.2、Maven下载安装

3.2.1、Maven下载

http://maven.apache.org/download.cgi

3.2.2、配置环境变量

添加M2_HOME:指向Maven解压后文件夹所在根目录

编辑Path:添加%M2_HOME%\bin;

3.2.3、配置Maven配置文件(本地仓库路径、镜像)

将Maven安装文件夹下conf文件夹中的settings.xml拷贝一份放在电脑home下的.m2文件夹中

对本地home下.m2中的settings.xml进行修改:

(1)可以修改本地仓库的存储位置(可选),默认存储在home下.m2文件夹中:

(2)可以修改中央仓库的访问路径,修改为英文的这个路径,可以加快访问速度,减小中央仓库压力:

3.2.4、用Maven创建项目

(1)首先用Eclipse集成Maven,推荐使用4.3(Kepler)及以上版本Eclipse,因为自己集成了Maven插件m2e

(2)配置Eclipse使用刚刚下载的Maven,以及刚刚配置的settings.xml配置文件:

    在eclipse中选择Window-Preferences,弹出以下窗口,然后点击Installations,在右侧点击Add添加按钮:

找到下载安装的Maven文件夹根目录,点击Finish:

勾选刚刚添加的maven,点击Apply,最后点击OK,配置完成:

(3)创建一个Maven项目:

Eclipse中左侧栏右键,选择New-Project

选择Maven Project,点击Next:

再次Next:

选择一个符合类型的,点击Next:

填写Group Id,Artifacted Id,Version,Package,点击Finish:

(4)修改pom.xml

<!-- 加入变量,替代我们用到的工程版本 -->
 <properties>
 	<commons-lang-version>2.6</commons-lang-version>
 	<slf4j-version>1.7.6</slf4j-version>
 	<spring-version>4.1.3.RELEASE</spring-version>
 </properties>

 <!-- 配置依赖管理:让maven帮我们管理传递依赖 -->
 <dependencyManagement>
 	<dependencies>
 		<dependency>
 			<groupId>org.springframework</groupId>
 			<artifactId>spring-framework-bom</artifactId>
 			<version>${spring.version}</version>
 			<scope>import</scope>
 		</dependency>
 	</dependencies>
 </dependencyManagement>

 <!-- 配置这个项目所依赖的包 -->
 <dependencies>
   <dependency>
     <groupId>junit</groupId>
     <artifactId>junit</artifactId>
     <version>3.8.1</version>
     <scope>test</scope>
   </dependency>

   <dependency>
   	<groupId>org.springframework</groupId>
   	<artifactId>spring-webmvc</artifactId>
   	<version>4.1.3.RELEASE</version>
   </dependency>

   <dependency>
   	<groupId>commons-lang</groupId>
   	<artifactId>commons-lang</artifactId>
   	<version>2.6</version>
   </dependency>

   <dependency>
   	<groupId>org.slf4j</groupId>
   	<artifactId>slf4j-log4j12</artifactId>
   	<version>1.7.6</version>
   	<exclusions>
   		<exclusion>
   			<groupId>org.slf4j</groupId>
   			<artifactId>slf4j-api</artifactId>
   		</exclusion>
   	</exclusions>
   </dependency>

 </dependencies>

 <!-- 添加组件:jetty是为了方便测试运行 -->
 <build>
 	<plugins>
 		<plugin>
 			<groupId>org.eclipse.jetty</groupId>
 			<artifactId>jetty-maven-plugin</artifactId>
 			<version>9.2.2.v20140723</version>
 		</plugin>
 	</plugins>
 </build>

如果当前包本地仓库,不存在,可以点击项目,右键,选择Maven-Add Dependency

填写Group Id, Artifacted Id, Version之后,点击OK,Maven就会自动从Maven仓库下载对应版本的jar包到本地仓库中:

(5)配置WEB应用,修改web.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-3.0.xsd
    http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
    http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">

    <!-- 激活@Required @Autowired @Resource等标注 -->
    <context:annotation-config/>

    <!-- DispatcherServlet上下文,只搜索@Controller标注的类,不搜索其他标注的类 -->
    <context:component-scan base-package="com.ztl.springmvc.controller">
    	<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
    </context:component-scan>
    <!-- 让DispatcherServlet启用基于Annotation的HandlerMapping -->
    <mvc:annotation-driven/>

    <!-- 将静态文件指定到某个特殊的文件夹中统一处理 -->
    <mvc:resources location="/resources/" mapping="/resources/**"/>

    <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    	<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
    	<property name="prefix" value="/WEB-INF/jsp/"/>
    	<property name="suffix" value=".jsp"/>
    </bean>

    <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
    	<property name="exceptionMappings">
    		<props>
    			<prop key="com.ztl.springmvc.UserException">error</prop>
    			<prop key="java.lang.NullPointException">exception</prop>
    		</props>
    	</property>
    </bean>
</beans>

(6)创建一个Controller,以及对应的页面,写个简单demo

写一个HelloMvcController类:

package com.ztl.springmvc.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
@RequestMapping("/hello")
public class HelloMvcController {
	@RequestMapping("/sayhello")
	public String sayHello(){
		return "home";
	}
}

通过pom.xml中配置的jetty插件来进行启动测试:

使用cmd命令行,找到项目地址,然后找到当前这个模块项目:

当看见Started Jetty Server时,则代表启动完成了,可以在浏览器访问了

在浏览器地址栏输入http://localhost:8080/hello/sayhello进行访问:

以上就是如何理解SpringMVC的详细内容,更多关于SpringMVC的资料请关注我们其它相关文章!

(0)

相关推荐

  • SpringMVC使用@PathVariable接收参数过程解析

    PathVariable 映射 URL 绑定的占位符 带占位符的 URL 是 Spring3.0 新增的功能,该功能在SpringMVC 向 REST 目标挺进发展过程中具有里程碑的意义 通过 @PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中:URL 中的 {xxx} 占位符可以通过@PathVariable("xxx") 绑定到操作方法的入参中. 使用MVC时,总是出现一些问题,当然都是使用造成的. 今天遇到一个问题,使用@PathVariable

  • 解决SpringMVC项目连接RabbitMQ出错的问题

    在第一次启动项目的时候,由于使用了RabbitMQ的默认guest账号,怎么也登不进去,后来还是在Admin重新创建了一个其他的账号,然后开启所有的权限,最后在配置文件中修改了账号,这样才成功连接rabbitmq. 但是到今天重新启动项目的时候,想试试guest账号还行不行,尝试了一次,居然可以重新启动了,吃惊! 在此记录,以防今后忘记. 补充:解决rabbitmq无法连接导致的错误 最近学写项目的时候用到rabbitmq始终无法连接,踩了挺多坑的,希望分享出来,让大家少踩一些. 错误提示是这样

  • Spring MVC获取HTTP请求头的两种方式小结

    1 前言 请求是任何Web服务要关注的对象,而请求头也是其中非常重要的信息.本文将通过代码讲解如何在Spring MVC项目中获取请求头的内容.主要通过两种方式获取: (1)通过注解@RequestHeader获取,需要在Controller中显式获取: (2)通过RequestContextHolder获取,可以任何地方获取. 接下来通过代码讲解. 2 通过注解@RequestHeader获取 需要在Controller中显示使用@RequestHeader. 2.1 获取某个请求头 只获取其

  • Spring MVC数据处理和乱码问题详解

    一.数据处理 1.1 处理提交数据 1.1.1 提交的域名称和处理方法的参数名一致 提交数据:http://localhost:8080/hello?name=test 处理方法: @RequestMapping("/hello") public String hello(String name){ System.out.println(name); return "hello"; } 后台输出test 1.1.2 提交的域名称和处理方法的参数名不一致 提交数据:h

  • 浅谈springMVC中controller的几种返回类型

    Controller方法的返回值可以有以下几种: 1.返回ModelAndView 返回ModelAndView时最常见的一种返回结果.需要在方法结束的时候定义一个ModelAndView对象,并对Model和View分别进行设置. 2.返回String 1):字符串代表逻辑视图名 真实的访问路径="前缀"+逻辑视图名+"后缀" 注意:如果返回的String代表逻辑视图名的话,那么Model的返回方式如下: public String testController(

  • SpringMVC异步处理操作(Callable和DeferredResult)

    官方文档中说DeferredResult和Callable都是为了异步生成返回值提供基本的支持.简单来说就是一个请求进来,如果你使用了DeferredResult或者Callable,在没有得到返回数据之前,DispatcherServlet和所有Filter就会退出Servlet容器线程,但响应保持打开状态,一旦返回数据有了,这个DispatcherServlet就会被再次调用并且处理,以异步产生的方式,向请求端返回值. 这么做的好处就是请求不会长时间占用服务连接池,提高服务器的吞吐量. Ca

  • springmvc 结合ajax批量新增的实现方法

    1. 需要注意的问题 mvc框架的处理日期问题 @ResponseBody响应对象是自定义对象,响应不是json @ResopnseBody响应自定义对象时,日期为是long类型的数 结束数据方法的参数,该如何定义?接收多个对象? 2. 页面代码 <%@ page language="java" isELIgnored="false" contentType="text/html; charset=UTF-8" pageEncoding=&

  • SpringMVC和rabbitmq集成的使用案例

    1.添加maven依赖 <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-client</artifactId> <version>3.5.1</version> </dependency> <dependency> <groupId>org.springframework.amqp</groupId>

  • SpringMVC集成redis配置的多种实现方法

    第一步:下载并安装Redis(网上已经有很多安装教程在此不细讲了) 第二步:pom文件引入jar包 在此需要注意Redis和jedis连接工厂版本 redsi:https://mvnrepository.com/artifact/org.springframework.data/spring-data-redis jedis:https://mvnrepository.com/artifact/redis.clients/jedis <!-- redis --> <dependency&

  • 基于IDEA创建SpringMVC项目流程图解

    作为一名从.NET转Java的小渣渣,之前都是听说Java配置复杂,今天算是见识到了.甚是怀念宇宙第一IDE VS和.NET高效的开发. 网上大多教程是基于Eclipse的,即使按照IDEA的教程做,第一次上手,或多或少有些问题,特意在这里做个笔记和分享. 我的IDEA版本是2019.2,Tomcat是9.0,JDK是1.8,按照以下步骤操作,应该没啥问题. 1.创建项目 2.命名 3.等待jar包下载完毕 下面是我创建完后,文件目录结构 4.创建所需的文件夹 在WEB-INF下创建classe

随机推荐