文章目录
SpringMVC
Spring web mvc 和Struts都属于表现层的框架,它是Spring框架的一部分。
提供了MVC架构和用于开发灵活和松散耦合的web应用程序组件。MVC模式导致应用程序的不同方面(用户输入逻辑,功能业务逻辑,前端UI逻辑)分离,同时提供这些元素之间的松散耦合。
Model(模型):封装了应用程序数据,通常由POJO类组成。
View(视图):前端和UI,负责渲染模型数据,一般来说它生成客户端浏览器可以解释HTML输出。
Controller(控制器):处理用户请求,构建适当的模型,并将其传递给视图进行渲染。
1 处理流程
2 demo
- pom.xml添加相关依赖
<spring.version>5.1.5.RELEASE</spring.version>
// spring核心包
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
// springMVC依赖
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
- pom.xml中添加maven插件,不用本地Tomcat,利于项目转移
配置一下:Command line: tomcat7:run
// 加一个Tomcat插件
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.2</version>
<configuration>
<port>8080</port>
<path>/</path>
</configuration>
</plugin>
- spring-web.xml
// 扫描controller包,开启注解扫描
<context:componen-scan base-package="com.java201"/>
- web.xml 配置,接收请求
// 配置前端控制器
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>
org.springframework.web. servlet.DispatcherServlet
</servlet-class>
// 加载配置文件
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-web.xml</param-value>
</init-param>
// 随容器启动而加载
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMVC</servlet-name>
<url-pattern>/</url-pattern> // 匹配所有请求
</servlet-mapping>
注意:ur-pattern 中的 / 和 / *
/ 会匹配到 / login 这样的路径型的 url,不会匹配到模式为*.jsp 这样的后缀型 url。故经过视图解析器后返回 jsp 视图时不会再进入 DispatcherServlet。为什么 JSP 页面的请求并不会命中这个 Servlet,那是因为 servlet 容器内建的 JSP Servlet 将会被调用,而这个容器内建的 JSP Servlet 已经默认地映射在了*.jsp 上。但还是能拦截到静态资源,如 * .js, * . css。
/ * 会匹配所有的 url:路径型的和后缀型的 url(包括/login, * .jsp, * .js 和*.html 等)。故经过视图解析器后返回 jsp 视图时会再进入 DispatcherServlet,导致找不到对应的 controller 所以报 404 错。
除了使用 / 之外,url-pattern 还可以进行后缀名匹配,如: .action.
- IndexController.java(添加注解@Controller)
public class IndexController {
@RequestMapping("/home")
public ModelAndView home() {
ModelAndView ma = new ModelAndView();// 用于保存数据和视图
// 指定jsp视图
ma.setViewName("/home.jsp");// WEB-INF/pages/hello.jsp
ma.addObject("name","小刚"); // 发送数据到视图,原始方式
return ma;
}
}
-
添加页面home.jsp
-
结果截图
3 SpringMVC架构
3.1 框架结构
3.2 架构流程
系统启动:
- 1.加载web.xml
- 2.初始化DispatcherServlet
- 3.加载Spring-web.xml
- 4.扫描Controller(前提必须是有@Controller注解)
- 5.通过反射去解析对应的方法对象:
5.1 解析方法上的请求映射注解
5.2 将请求路径作为key,controller对象作为value,存放到HashMap1
5.3 将请求路径作为key,方法对象作为value,存放到HashMap2
3.3 组件说明
DispatcherServlet:前端控制器
用户请求到达前端控制器,它就相当于 mvc 模式中的 c, dispatcherServlet 是整个流程控制的中心,由它调用其它组件处理用户的请求, dispatcherServlet 的存在降低了组件之间的耦合性。
HandlerMapping:处理器映射器
HandlerMapping 负责根据用户请求 url 找到 Handler 即处理器, springmvc 提供了不同的映射器实现不同的映射方式,例如:配置文件方式,实现接口方式,注解方式等。
注解式处理器映射器,对类中标记了 @ResquestMapping 的方法进行映射。根据@ResquestMapping 定义的 url 匹配@ResquestMapping 标记的方法,匹配成功返回 HandlerMethod 对象给前端控制器。HandlerMethod 对象中封装 url 对应的方法Method。从 spring3.1 版本开始,废除了 DefaultAnnotationHandlerMapping 的使用,推荐使用 RequestMappingHandlerMapping 完成注解式处理器映射。
Handler:处理器
Handler 是继 DispatcherServlet 前端控制器的后端控制器,在 DispatcherServlet
的控制下 Handler 对具体的用户请求进行处理。由于 Handler 涉及到具体的用户业务
请求,所以一般情况需要程序员根据业务需求开发 Handler。
HandlerAdapter:处理器适配器
通过 HandlerAdapter 对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。
ViewResolver:视图解析器
View Resolver 负责将处理结果生成 View 视图, View Resolver 首先根据逻辑视图名解析成物理视图名,即具体的页面地址,再生成 View 视图对象,最后对 View 进行渲染,将处理结果通过页面展示给用户。
View:视图
springmvc 框架提供了很多的 View 视图类型的支持,包括:jstlView、freemarkerView、pdfView 等。 一般情况下需要通过页面标签或页面模版技术将模型数据通过页面展示给用户,需要由程序员根据业务需求开发具体的页面。
在 springmvc 的各个组件中,处理器映射器、处理器适配器、视图解析器称为springmvc 的三大组件。
需要用户开发的组件有 handler、 view
3.4 视图解析器
注意:如果不配置映射器和适配器就会使用默认的不推荐的映射器和适配器,所以尽量配置。
spring-web.xml中添加:
<!-- 自动加载 推荐的处理器 映射器、适配器-->
<mvc:annotation-driven/>
4 Controller方法的返回值
4.1 返回ModelAndView
对象中可添加model数据,指定view之前使用的方式,不推荐使用
@Controller
public class IndexController {
@RequestMapping("/home")
public ModelAndView home() {
ModelAndView ma = new ModelAndView();
// 指定视图
ma.setViewName("/home.jsp");
// 发送数据到视图
ma.addObject("name","小刚");
return ma;
}
@RequestMapping("/home1")
public ModelAndView home1() {
ModelAndView ma = new ModelAndView();
ma.setViewName("/home1.jsp");
return ma;
}
}
4.2 返回void
在Controller方法形参上可以定义request和response,使用 request 或 response 指定响应结果。通过 request 或者 response 完成页面的重定向或者转发。
@RequestMapping("/testVoid")
public void testVoid(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setAttribute("user","刚刚呀");
request.getRequestDispatcher("/WEB-INF/pages/qq.jsp").forward(request,response);
}
4.3 返回字符串
controller 方法返回字符串可以指定逻辑视图名,通过视图解析器解析为物理视图地址。如果需要数据,可以使用 Model 对象进行接收,也可以使用该方法重定向或者转发到另一
个 controller。
重定向到 jsp
如果 model 中有数据,会以键值对的形式发送到另一个 jsp 页面中。
@RequestMapping("/yyy")
public String yyy(Model model) { //注入model对象
model.addAttribute("name","宾宾");
return "yyy"; //页面名
// return "redirect:/yyy.jsp"; // 重定向页面不能放在WEB-INF下面
}
注意:也可以直接重定向到 Controller。比如,return “redirect:/yyy.action”;
转发到 jsp
springmvc 默认是转发,可以直接返回逻辑视图名,也可以手动编写转发路径。
return “forward:/WEB-INF/pages/qq.jsp”;
注意:也可以直接转发到 Controller