SpringMVC基础学习(一)—初识SpringMVC
一、HelloWorld
1.导入SpringMVC所需的jar包
2.配置web.xml
配置DispatcherServlet。DispatcherServlet默认加载/WEB-INF/<servletName-servlet>.xml 的Spring配置文件,启动Web层的Spring容器。可以通过contextConfigLocation初始化参数自定义配置文件的位置和名称。
web.xml
<?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>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc.xml</param-value> </init-param> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</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" xmlns:mvc="http://www.springframework.org/schema/mvc" 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 http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 配置自动扫描的包 --> <context:component-scan base-package="com.kiwi"/> <!-- 配置视图解析器: 如何把handler方法返回值解析作为实际的物理视图--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> </beans>
4.创建请求处理类
@Controller
public class HelloWorld{
/*
* 1.使用@RequestMapping注解来映射请求的URL
* 2.返回值会通过视图解析器解析为实际的物理视图,对于InternalResourceViewResolver会做如下解析
* prefix + returnVal + "suffix 会得到实际的物理视图,然后做转发操作
* /WEB-INF/views/success.jsp
*/
@RequestMapping("/helloWorld")
public String hello(){
System.out.println("Hello World");
return "success";
}
}
index.jsp
<a href="helloWorld">Test</a>
二、使用@RequestMapping映射请求
1.@RequestMapping修饰类
(1)SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些URL请求。
(2)@RequestMapping可以在类和方法处定义:
类定义处: 提供初步的请求映射信息,相当于WEB应用的根目录。
方法处: 提供细分映射信息,相当于类定义处URL,如果类定义未标注,相当于WEB根目录。
@Controller
@RequestMapping("/demo")
public class TestDemo{
private static final String SUCCESS = "success";
/*
* 1.@RequestMapping不仅可以修饰方法,还可以修饰类
*/
@RequestMapping("/test")
public String test(){
System.out.println("test()......");
return SUCCESS;
}
}
此时请求路径: http://localhost:8080/springmvc-01/demo/test
(1)类定义处@RequestMapping限定处理器类可以处理所有URI为"/demo"的请求,它相当于WEB容器的根目录。
(2)处理器可以定义多个方法来处理来之"/demo"的请求。
2.请求参数、请求方法、请求头
(1)@RequestMapping除了可以使用请求URL映射请求外,还可以使用请求方法、请求参数及请求头映射请求。
(2)value、method、params及headers分别表示请求URL、请求方法、请求参数、请求头。
(3)params和headers支持简单的表达式。
param1: 请求必须包含param1的请求参数。
!param1: 表示请求不能包含名为param1的请求参数。
param1 != value1: 请求包含名为param1的请求参数但是不能为value1。
/*
* 1.请求方式必须是GET请求
* 2.请求参数必须带有"name"
* 3.eg: http://localhost:8080/springmvc-01/demo/method?name=Tom
*/
@RequestMapping(value="/method",method=RequestMethod.GET,params="name")
public String testMethod(){
return SUCCESS;
}
3.匹配符
?: 匹配文件名中的一个字符。
*: 匹配文件名中的任意字符。
**: 匹配多层路径。
/a/*/b
匹配: /a/aaa/b、/a/bbb/b
/a/**/b
匹配: /a/b、/a/aaa/bbb/b
/a/b??
匹配: /a/baa、/a/bbb
4.@PathVariable映射URL绑定的占位符
通过@PathVariable可以将URL中站位符参数绑定到控制器处理方法的入参中。
@RequestMapping(value = "/user/{userId}/role/{roleId}",method = RequestMethod.GET)
public String getLogin(@PathVariable("userId") String userId,
@PathVariable("roleId") String roleId){
System.out.println("User Id : " + userId);
System.out.println("Role Id : " + roleId);
return SUCCESS;
}
http://localhost:8080/springmvc-01/demo/user/11/role/22
结果:
User Id : 11
Role Id : 22
5.使用@RequestParam绑定请求参数值
(1)在处理方法入参处使用@RequestParam可以把请求参数传递给请求方法。
(2)value: 参数名。
required: 是否必须,默认为true。表示请求参数必须包含对应的参数,不存在,将抛出异常。
@RequestMapping("/param")
public String testParam(@RequestParam(value="username",required=false) String username,
@RequestParam(value="password") String password){
System.out.println("username: " + username);
System.out.println("password: " + password);
return SUCCESS;
}
http://localhost:8080/springmvc-01/demo/param?username=Tom&password=123
结果:
username: Tom
password: 123
6.使用POJO对象绑定请求参数值
SpringMVC会按请求参数名和POJO属性名进行自动匹配,自动为该对象填充属性值,支持级联属性。
index.jsp
<form action="${pageContext.request.contextPath}/demo/test" method="post"> username: <input type="text" name="username"/><br> password: <input type="password" name="password"/><br> province: <input type="text" name="address.province"/><br> city: <input type="text" name="address.city"/><br> <input type="submit" value="提交"/> </form>
User.java
TestDemo.java
@Controller
@RequestMapping("/demo")
public class TestDemo{
private static final String SUCCESS = "success";
@RequestMapping("/test")
public String testPOJO(User user){
System.out.println(user);
return SUCCESS;
}
}
结果:
User [username=Tom, password=123, address=Address [province=BeiJing, city=Changping]]
7.使用Servlet API作为入参
可以接受以下类型的参数:
1.HttpServletRequest、2.HttpServletResponse、3.HttpSession、4.java.security.Principal
5.Locale、6.InputStream、7.OutputStream、8.Reader
@RequestMapping("/test")
public String testServlet(HttpServletRequest request){
String username = request.getParameter("username");
System.out.println(username);
return SUCCESS;
}
http://localhost:8080/springmvc-01/demo/test?username=Tom
结果:
Tom



浙公网安备 33010602011771号