运行原理:
- 上图中步骤 6、7 在 dispatcherServlet 内部进行
DispatcherServlet 作用:
- 响应 request 和 response
- 查找 handler (根据 url)
- 调用 handlerMapping 处理 handler (根据 xml 、注解)
- 调用 View Resolver 解析 modelAndView
一个中心:(DispatcherServlet 不需要开发)
三个组件:(不需要开发)
处理器映射器 HandlerMapping
处理器适配器 HandlerAdapter
视图解析器 ViewResolver
Handler:(需要开发)
处理器,理解成action
View:(需要开发)
需要开发页面:jsp
用 springmvc 写一个 helloWorld,来测试 @RequestMapping 的属性(修饰类)
@RequestMapping(value="访问地址",method=RequestMethod.POST)
-
结构如下
- 步骤:
– 加入 jar 包
– 在 web.xml 中配置 DispatcherServlet
– 加入 Spring MVC 的配置文件
– 编写处理请求的类处理器,并加注解@Controller标识为处理器
– 编写视图
1、在 lib 中加入 jar 包,并加入 classpath
– commons-logging-1.1.3.jar
– spring-aop-4.0.0.RELEASE.jar
– spring-beans-4.0.0.RELEASE.jar
– spring-context-4.0.0.RELEASE.jar
– spring-core-4.0.0.RELEASE.jar
– spring-expression-4.0.0.RELEASE.jar
– spring-web-4.0.0.RELEASE.jar
– spring-webmvc-4.0.0.RELEASE.jar
2、在 web.xml 中,配置 dispatcherServlet 参数
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://java.sun.com/xml/ns/javaee"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd"
id="WebApp_ID" version="2.5">
<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:SpringMVC.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>
</web-app>
3、写 SpringMVC 配置文件 SpringMVC.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"
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">
<context:component-scan base-package="com.atguigu.springmvc"/>
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
</bean>
</beans>
4、类处理器
package com.atguigu.springmvc.handlers;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloWorld {
@RequestMapping("/springmvc")
public String hello(){
System.out.println("hello world");
return "success2";
}
}
5、编写 index.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>index.jsp</title>
</head>
<body>
<a href="springmvc">success page.</a>
</body>
</html>
6 编写视图 success2.jsp
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>success page</title>
</head>
<body>
<h1>success!</h1>
</body>
</html>
-
结果如下,点击超链接
如果对上述实例如下改动(测试 @RequestMapping既可以修饰类也可以修饰方法):
上文第4步 对类处理器文件作出修改(其他文件不变)
package com.atguigu.springmvc.handlers;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@RequestMapping(value="/springmvc")
@Controller
public class HelloWorld {
@RequestMapping(value="/springmvc")
public String hello(){
System.out.println("hello world");
return "success2";
}
}
则对应的访问 URL 地址变为如下:访问地址从 localhost:9090/springmvc 到 localhost:9090/springmvc/springmvc
上文第5步 index.jsp 修改访问路径
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>index.jsp</title>
</head>
<body>
<a href="springmvc/springmvc">success page.</a>
</body>
</html>
访问地址从 localhost:9090/springmvc 到 localhost:9090/springmvc/springmvc:
- 结论:
@RequestMapping 既可以修饰类,也可以修饰方法
– 修饰 Class 类:提供初步映射地址
– 修饰 Method 方法:提供次一级的映射地址
若类定义处未标注 @RequestMapping,则方法处标记的 URL 相对于
WEB 应用的根目录
继续阅读 SpringMVC 的那点儿事 (二)---测试@RequestMapping的method属性
Reference
感谢 佟刚 大神的 SpringMVC 的视频教程