实现SpringMVC最基本步骤
– 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
而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开头的,否则找不到路径。
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到该视图。
<完>