一、SpringMVC的第一个HelloWorld
Spring MVC主要由DispatcherServlet、处理器映射、处理器(控制器)、视图解析器、视图组成。他的两个核心是:
处理器映射:选择使用哪个控制器来处理请求
视图解析器:选择结果应该如何渲染
1.导入基本所需jar包:
2.在Web.xml配置文件中配置SpringMVC
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<!--配置DispatcherServlet -->
<servlet>
<servlet-name>springDispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--配置SpringMVC的一个初始化参数:作用是配置SpringMVC配置文件的位置和名称 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springDispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
DispatcherServlet是前置控制器,配置在web.xml文件中的。拦截匹配的请求,Servlet拦截匹配规则要自已定义,把拦截下来的请求,依据相应的规则分发到目标Controller来处理,是配置spring MVC的第一步。
3.在src下添加springmvc.xml配置文件
<!-- 自动扫描controller包下的所有类,使其认为spring mvc的控制器 -->
<context:component-scan base-package="com.study.springmvc.handlers" />
<!-- 配置视图解析器:如何把handler方法返回值解析为实际的物理视图 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
4.在WEB-INF下添加views文件夹,用于存放jsp页面
5.建立扫描的包并创建类用于实现helloworld
package com.study.springmvc.handlers;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class HelloWorld {
/**
* 1.使用 @RequestMapping 注解来映射请求的url
* 2.返回值会通过视图解析器解析为实际的物理视图,InternalResourceViewResolver视图解析器会做如下的解析:
* prefix + returnVal + suffix,通过这样的方式得到实际物理视图,然后做转发操作
* 例如:/WEB-INF/views/ +success+.jsp →→→→ /WEB-INF/views/success.jsp
*/
@RequestMapping("/helloworld")
public String sayHello(){
System.out.println("HelloWorld");
return "success";
}
}
6.在index.jsp中编写代码,实现导向上述helloworld地址的链接
<body>
<a href="helloworld">Hello World</a>
</body>
7.在views文件夹下创建success.jsp
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<base href="<%=basePath%>">
<title>success page</title>
</head>
<body>
<h4>success page</h4>
</body>
</html>
8.将工程加入tomcat中。启动服务器,访问:http://localhost:8080/springMVC-study/index.jsp二、@RequestMapping注解的基本使用
@RequestMapping 注解为控制器指定可以处理哪些 URL 请求。
1.@RequestMapping 修饰类和方法
除了类似于上述代码中可以放在方法的上面修饰方法,还可以用来修饰类。
1).类定义处:提供初步的请求映射信息,相当于WEB应用的根目录。
2).方法处:提供进一步的细分映射信息。若类定义处没有使用@RequestMapping ,则方法处的请求映射信息就相当于WEB应用的根目录。
2.@RequestMapping 的value属性value的值:指定请求的实际地址
@RequestMapping("/helloworld")和@RequestMapping(value="/helloworld")一样
3.@RequestMapping 的method属性
method的值:指定请求的method类型, GET、POST、PUT、DELETE等
@RequestMapping(value="/helloworld",method=RequestMethod.POST)
public String test(){
System.out.println("HelloWorld");
return "success";
}
当请求的方法指定请求方式时,则需要用对应的请求方式进行请求,否则会出现类似下面的错误:定义的POST,却使用了GET请求方式
4.@RequestMapping 的params属性: 指定request中必须包含某些参数值时,才让该方法处理。
5.@RequestMapping 的headers属性: 指定request中必须包含某些指定的header值,才能让该方法处理请求。
6. @RequestMapping 和@PathVariable的配合使用@PathVariable 可以来映射url中的占位符到目标方法的参数中
例如:index.jsp:
<a href="pathVariable/aha">pathVariable</a>
HelloWorld.java:
/**
* @PathVariable 可以来映射url中的占位符到目标方法的参数中
*/
@RequestMapping("/pathVariable/{str}")
public String pathVariable(@PathVariable("str") String aaa){
System.out.println("pathVariable:"+aaa);
return "success";
}
输出结果:pathVariable:aha