MVC模型:
MVC 全名是 Model View Controller,是模型(model)-视图(view)-控制器(controller)的缩写,是一种用于设计创建 Web 应用程序表现层的模式。MVC 中每个部分各司其职:
Model (模型) :
通常指的就是我们的数据模型。作用一般情况下用于封装数据。
View (视图) :
通常指的就是我们的 jsp 或者 html。作用一般就是展示数据的。
通常视图是依据模型数据创建的。
Controller (控制器) :
是应用程序中处理用户交互的部分。作用一般就是处理程序逻辑的。
它相对于前两个不是很好理解,这里举个例子:
例如:
我们要保存一个用户的信息,该用户信息中包含了姓名,性别,年龄等等。
这时候表单输入要求年龄必须是 1~100 之间的整数。姓名和性别不能为空。并且把数据填充到模型之中。此时除了 js 的校验之外,服务器端也应该有数据准确性的校验,那么校验就是控制器的该做的。当校验失败后,由控制器负责把错误页面展示给使用者。如果校验成功,也是控制器负责把数据填充到模型,并且调用业务层实现完整的业务需求。
SpringMVC入门案例:
配置核心容器---一个Servlet
/span> "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd" ><web-app> <display-name>Archetype Created Web Applicationdisplay-name> <servlet> <servlet-name>dispatcherServletservlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class> <init-param> <param-name>contextConfigLocationparam-name> <param-value>classpath:springmvc.xmlparam-value> init-param> <load-on-startup>1load-on-startup> servlet> <servlet-mapping> <servlet-name>dispatcherServletservlet-name> <url-pattern>/url-pattern> servlet-mapping>web-app>
web.xml拆分解释:
配置springmvc的核心控制器
<servlet-name>dispatcherServletservlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServletservlet-class>
配置初始化参数用于读取springmvc的配置文件
<init-param> <param-name>contextConfigLocationparam-name> <param-value>classpath:springmvc.xmlparam-value>init-param>
配置 servlet 的对象的创建时间点:应用加载时创建。取值只能是非 0 正整数,表示启动顺序
1on-startup>
发任何请求都会经过servlet
<servlet-mapping> <servlet-name>dispatcherServletservlet-name> <url-pattern>/url-pattern>servlet-mapping>
创建 spring mvc 的配置文件
<?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans" xmlns:mvc="http://www.springframework.org/schema/mvc" xmlns:context="http://www.springframework.org/schema/context" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/mvchttp://www.springframework.org/schema/mvc/spring-mvc.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"> <context:component-scan base-package="cn.itcast">context:component-scan> <bean id="internalResourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/pages/">property> <property name="suffix" value=".jsp">property> bean> <mvc:annotation-driven>mvc:annotation-driven>beans>
在 SpringMVC 的各个组件中,处理器映射器、处理器适配器、视图解析器称为 SpringMVC 的三大组件。
自动加载 RequestMappingHandlerMapping (处理映射器) 和
RequestMappingHandlerAdapter ( 处 理 适 配 器 ),可 用 在 springmvc.xml 配 置 文 件 中 使 用替代注解处理器和适配器的配置。
编写控制器并使用注解配置
//控制器类@Controllerpublic class HelloController { /** * 入门案例 * @return */ @RequestMapping(path="/hello") //请求映射 (相对路径) public String sayHello(){ System.out.println("hello SpringMVC"); return "success"; //返回值 mvc框架默认规则返回值表示jsp文件名 所以提供success.jsp }}
index.jsp
"text/html;charset=UTF-8" language=<html><head> <title>Titletitle>head><body> <h3>入门程序h3> <a href="hello">入门程序a>body>html>
suceess.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %><html><head> <title>Titletitle>head><body> <h3>入门成功了h3>body>html>
运行结果
入门程序原理分析
1、服务器启动,应用被加载。读取到 web.xml 中的配置创建 spring 容器并且初始化容器中的对象。从入门案例中可以看到的是:HelloController 和 InternalResourceViewResolver,但是远不止这些。
2、浏览器发送请求,被 DispatherServlet 捕获,该 Servlet 并不处理请求,而是把请求转发出去。转发的路径是根据请求 URL,匹配@RequestMapping 中的内容。
3、匹配到了后,执行对应方法。该方法有一个返回值。
4、根据方法的返回值,借助 InternalResourceViewResolver 找到对应的结果视图。
5、渲染结果视图,响应浏览器。
入门案例执行流程:
1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象,就会加载springmvc.xml配置文件;
2. 开启了注解扫描,那么HelloController对象就会被创建;
3. 从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解找到执行的具体方法;
4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件;
5. Tomcat服务器渲染页面,做出响应。
RequestMapping注解:
作用:
用于建立请求 URL 和处理请求方法之间的对应关系。
出现位置:
类上:请求 URL 的第一级访问目录。此处不写的话,就相当于应用的根目录。写的话需要以/开头。它出现的目的是为了使我们的 URL 可以按照模块化管理。
@Controller@RequestMapping(path = "/user")public class HelloController { @RequestMapping(path="/hello") public String sayHello(){ System.out.println("hello SpringMVC"); return "success"; } }
方法上:请求 URL 的第二级访问目录。
属性:
value:用于指定请求的 URL。它和 path 属性的作用是一样的。只有一个属性时value可以省略。
method:用于指定请求的方式。
/** * public enum RequestMethod { GET, HEAD, POST, PUT, PATCH, DELETE, OPTIONS, TRACE; enum表示该类是一个枚举类 枚举类直接用类名加.属性就可以拿到值 */
params:用于指定限制请求参数的条件。它支持简单的表达式。要求请求参数的key和value必须和配置一模一样。
params = {"username"} 表示请求方法执行时必须传一个username属性,否则方法不会执行。
params = {"username=heiheihei"} 与请求的hehehe不一致,则不能访问到。
headers:用于指定限制请求消息头的条件。
注意:
以上四个属性只要出现 2 个或以上时,他们的关系是与的关系。
@RequestMapping(value = "/testRequestMapping",method = {RequestMethod.GET}, params = {"username"},headers = {"Accept"}) // @RequestMapping("/testRequestMapping") public String testRequestMapping(){ System.out.println("测试@RequestMapping注解..."); return "success"; }
"text/html;charset=UTF-8" language=<html><head> <title>入门程序title>head><body> <h3>入门程序h3><%-- <a href="hello">入门程序a>--%><%-- <a href="user/testRequestMapping">RequestMapping注解a>--%> <a href="user/testRequestMapping?username=hehehe">RequestMapping注解a>body>html>