关闭

SpringMVC-RequestMapping注解

182人阅读 评论(0) 收藏 举报
分类:

实现SpringMVC最基本步骤

1.添加 jar 包

– 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

在web.xml中输入Alt+/ 找到dispatcherservlet回车后,会自动补全要创建的内容。

DispatcherServert的URL设置说明:

<url-pattern>/</url-pattern>不会匹配*.jsp,即所有有效的的*.jsp(WEB-INF不能直接访问)都不会被Dispatcher分发,执行默认处理。除了*.jsp以外的所有网址都会被DispatchServlet进行映射控制。

<url-pattern>/*</url-pattern> 会匹配*.jsp,导致进入spring的DispatcherServlet类,然后去寻找controller,若找不到对应的controller会报错。

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
  <display-name>spring</display-name>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
  
	<servlet>
		<servlet-name>springDispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param><!-- 配置SpringMVC的配置文件位置 -->
			<!-- 这里可以不配置xml,使用默认位置WEB-INF/<servlet-name>-servlet.xml -->
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:springmvc.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>

	<!-- Map all requests to the DispatcherServlet for handling -->
	<servlet-mapping>
		<servlet-name>springDispatcherServlet</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>

</web-app>

3.加入 Spring MVC 的配置文件

在classpath路径下,java-src目录下添加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/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd
		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-4.2.xsd">
	
	<!-- 定义自动扫描注解的包 -->
	<context:component-scan base-package="spring"></context:component-scan>
	
	<!-- 定义视图解析器 -->
	<!-- 视图的URI是通过prefix+带有@RequestMapping注解函数的返回值+suffix构成 带有@RequestMaping的函数执行完后会自动转发到该操作-->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>
</beans>

4.编写RequestMapping

RequestMapping可以理解为控制器-(请求映射)注解,他可以将URL映射到对应的view
而view则是通过指定RequestMapping注解的函数的返回字符串,通过ResourceViewResolver解析得到。
1)视图解析方法
视图的URI是通过prefix+带有@RequestMapping注解函数的返回值+suffix构成 带有@RequestMaping的函数执行完后会自动转发到该操作
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
下面的例子中,函数在执行完后,会自动Foward到/WEB-INF/views/HelloSpringMVC.jsp页面

2)RequestMapping的可选配置
method 默认方法为RequestMethod.GET 可以指定为POST
params 不常用:是一个字符串数组,网页传递的参数通常被forward到的视图处理,所以这个不怎么常用。
-举例:params={"param1", "!param2", "param3=value1", "param4!=value2"}
-param1 标识必须包含param1参数
-!param1 表示必须不包含param1参数
-param1!=value1 表示请求必须包含名为param1的参数,值必须不为value1,如果是等号则相反。
如果网页中提交的参数不满足上面要求,则会提示 No matching handler method found
headers 仅作了解,是一个字符串数组,可以设置headers属性。

3)RequestMapping使用Ant风格通配符
仅支持三种类型的通配符
- ?:匹配文件名中的一个字符
- * : 匹配文件名中任意字符
- ** :匹配多层路径
比如:/test/h*/abc 则第二个文件名必须是h开头的,否则找不到路径。
package spring;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
//通过将ReqeustMapping修饰在类上,可以在App根目录上再指定相对目录。
//比如下面的hello函数,真正的网址会变成/appname/test/HelloSpringMVC
public class HelloSpringMVC {
	private static final String finalViewName = "HelloSpringMVC";
	
	@RequestMapping("/test/h*/antStyleWildcard")
	public String antStyleWildcard(){
		System.out.println("antStyleWildcard");
		return finalViewName; //默认使用的是Foward,若想是用redirect 则加上前缀即可:"redirect:abc"
	}
	
	@RequestMapping(value="/test/HelloSpringMVC", method=RequestMethod.GET,
			params={"param1", "!param2", "param3=value1", "param4!=value2"})
	public String Hello(){
		System.out.println("HelloSpringMVC");
		return finalViewName;
	}
}

5.编写视图

视图可以通过jsp实现,也可以通过其他的工具。

这里在通过jsp创建视图文件:在appname/WEB-INF/HelloSpringMVC.jsp

@RequestMapping注解的函数中有返回HelloSpringMVC字符串的控制器,会被ResourceViewResolver解析Foward到该视图。

<完>

0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    最新评论