小白第九篇 Spring MVC流程及小实例
Spring MVC浅析
Spring MVC 是一种基于Servlet的技术,提供了核心控制器DispatcherServlet和相关的组件以及松散的结构。
基本的运行流程
所有的组件围绕着核心处理器来进行执行,结构很松散;
处理器映射由处理器Handler和拦截器组成;
处理器适配器就是通过上下文找到对应的适配器用以运行对应的Handler和拦截器。
小实例
- 运行环境
- Eclipse
- Tomcat 9.0
项目结构
- web.xml文件的基本配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" id="WebApp_ID" version="4.0">
<!-- 配置Spring IoC配置文件路径 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>/WEB-INF/applicationContext.xml</param-value>
</context-param>
<!-- 配置ContextLoaderListener初始化Spring IoC容器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!-- 配置DispatcherServlet -->
<servlet>
<servlet-name>dispatcher</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>2</load-on-startup>
</servlet>
<!-- 拦截配置 拦截以后缀为do的请求-->
<servlet-mapping>
<servlet-name>dispatcher</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<display-name>SSM09</display-name>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
- applicationContext.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-4.0.xsd">
</beans>
- Spring MVC配置文件 dispatcher-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:p="http://www.springframework.org/schema/p"
xmlns:tx="http://www.springframework.org/schema/tx" 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-4.0.xsd
http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-4.0.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
<!-- 与Spring MVC配置相关的内容 -->
<!-- 使用注解驱动 -->
<mvc:annotation-driven/>
<!-- 定义扫描装载的包 -->
<context:component-scan base-package="com.*"/>
<!-- 定义视图解析器 -->
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver"
p:prefix="/WEB-INF/jsp/"
p:suffix=".jsp"/>
<!-- 注解事务 -->
<tx:annotation-driven transaction-manager="transactionManager"/>
</beans>
- 定义一个简单的控制器
package com.ww.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
/**
* 控制器Demo
* @author WW
*/
@Controller("ControllerDemo")
//表明当请求的URI在 /demo下该控制器响应
@RequestMapping("/demo")
public class ControllerDemo {
@RequestMapping("/index")
public ModelAndView index() {
ModelAndView mv = new ModelAndView();
//视图名称 index
mv.setViewName("index");
return mv;
}
}
- 定义一个index的jsp页面
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Spring MVC Demo</title>
</head>
<body>
<h1>This is a Spring MVC Demo</h1>
</body>
</html>
- 测试
此处的/demo/index.do是对于控制器中通过@RequestMapping注解来约定的。
.do这个处理的方式是在web.xml文件中配置的拦截器的后缀。
index为指定的视图逻辑名,也就是控制器中定义的视图名。而在Spring MVC配置文件定义的视图解析器是在WEB-INF/jsp/*.jsp 从而一步步可以追踪到这个JSP文件并显示出来。
完成!
这个实例需要格外注意配置文件,这也是对于使用XML文件用于配置的一个小弊端吧!毕竟这个是可以通过注解的方式来配置的!但是刚刚开始入门还是使用XML文件配置的方式了解比较好一点!
对于配置DispatcherServlet当配置了servlet-name为dispatcher就需要配置一个WEB-INF/dispatcher-servlet.xml文件,这里servlet-name和文件名是有对应关系的!
当一个类继承AbstractAnnotationConfigDispatcherServletInitializer类的时候就可以进行替换XML文件达到配置的目的,举个例子:
package com.ww.config;
import org.springframework.web.servlet.support.AbstractAnnotationConfigDispatcherServletInitializer;
public class InitializerDemo
extends AbstractAnnotationConfigDispatcherServletInitializer{
//Spring IoC容器配置 装载各种Java Bean
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class<?>[] {};
}
//DispatcherServlet的URI映射关系配置 用以生成Web请求的上下文
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class<?>[] {DemoConfig.class};
}
//DispatcherServlet 拦截内容配置
@Override
protected String[] getServletMappings() {
return new String[] {"*.do"};
}
}
DemoConfig类可以生成视图解析器达到和例子一样的目的
package com.ww.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.ViewResolver;
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
import org.springframework.web.servlet.view.InternalResourceViewResolver;
@Configuration
@ComponentScan("com.*")
@EnableWebMvc
public class DemoConfig {
//视图解析器
@Bean(name="viewResolver")
public ViewResolver initViewResolver() {
InternalResourceViewResolver viewResolver =
new InternalResourceViewResolver();
//设置视图的前缀 后缀
viewResolver.setPrefix("/WEB-INF/jsp/");
viewResolver.setSuffix(".jsp");
return viewResolver;
}
}
这里的注解的方式就是使用@EnableWebMvc注解达到启动Spring MVC框架的配置。
使用这种情况就不再需要web.xml和其他的xml文件的配置了,可以都删掉,达到的效果却是一样的。