一、简单情境下
1、配置文件概述
2、注册转发器
在web.xml文件中,配置如下:
<?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"> <!-- 配置 DispatcherServlet --> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 --> <!-- 实际上也可以不通过 contextConfigLocation 来配置 SpringMVC 的配置文件, 而使用默认的. 默认的配置文件为: /WEB-INF/<servlet-name>-servlet.xml --> <!-- <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:springmvc.xml</param-value> </init-param> --> <load-on-startup>1</load-on-startup> <!-- load on starup 大于、等于0代表随系统启动后加载 ,数字越小优先级越高 ; 数值为负数时,启动时不加载,调用时再加载 --> </servlet> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <!-- 第一种:*.action 或者 *.do,访问以.action或*.do结尾 由DispatcherServlet进行解析 第二种:/,所以访问的地址都由DispatcherServlet进行解析,对于静态文件的解析需要配置不让DispatcherServlet进行解析 使用此种方式可以实现 RESTful风格的url 第三种:/*,这样配置不对,使用这种配置,最终要转发到一个jsp页面时, 仍然会由DispatcherServlet解析jsp地址,不能根据jsp页面找到handler,会报错。 --> <url-pattern>/</url-pattern> </servlet-mapping> <!-- 下面这个没有写不要紧,因为tomcat服务器默认 index为首页 --> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list> </web-app>
3、配置转发器
转发配置文件–>【前面web.xml配置的是在src下, 取名springmvc.xml文件。如果是默认配置应该在WEB-INF下即和web.xml同目录,取名dispatcherServlet-servlet.xml文件】,其中 配置自定扫描的包 ,是为了扫描指定包文件中,有@Controller ,@Component等注解的类文件。
<?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-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 对于注解的Handler可以单个配置 实际开发中建议使用组件扫描 --> <!-- <bean class="com.test.springmvc.handlers.HelloWorld" /> --> <!-- 可以扫描controller、service、...这里让扫描controller,指定controller的包,但是view的包下面的注解类就扫描不到了, 所以 com.test.springmvc.handlers 改成 com.test.springmvc就行啦,子目录都能扫描得到 --> <!--下面是 配置扫描 指定目录包 中的 java文件 --> <context:component-scan base-package="com.test.springmvc.handlers"></context:component-scan> <!-- 配置视图解析器【多个函数可选择】: 此解析器默认生成InternalResourceView,如果项目添加了jstl.jar包的话就会自动改为生成JstlView; 即如何把 handler 方法返回值解析为实际的物理视图,handler的返回值也可以具体是 /WEB-INF/XXXX/XXX.jsp,这样下面的试图解析器就不需要添加前缀和后缀了 --> <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、编写控制器
在dispatcherServlet-servlet.xml中,因为标明了自定义扫描包路径,来寻找控制器。于是我们就用代码来实现控制器。在包名 com.test.springmvc.handlers 下,创建 HelloWorld.java
[java]
package com.test.springmvc.handlers;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller // spring里面 又名handler 处理器
public class HelloWorld {
/**
* 1、使用RequestMapping 注解来映射 请求的url
* 2、返回值会通过视图解析器解析为实际的物理视图,
* 对于org.springframework.web.servlet.view.InternalResourceViewResolver
* 会做如下解析,prefix + returnVal + suffix 得到实际的物理视图。然后做转发操作。
* 即 WEB-INF/views/success.jsp
*/
@RequestMapping("/helloworld")
public String hello(){
System.out.println("hello world");
return "success";
}
}
[/java]
上面的请求路径为:projectname/helloworld
也可以在类上面多加一个 RequestMapping 注解,比如 xxx
那么请求路径为 projectname/xxx/helloworld
五、配置 返回结果 页
/WEB-INF/views/success.jsp 编辑如下:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>Insert title here</title> </head> <body> <h4> Success page </h4> </body> </html>
6、url请求测试结果
下面两个都能 正常访问
http://localhost:5858/springmvc-1/
http://localhost:5858/springmvc-1/index.jsp
WEB-INF只允许服务器访问,外部无法访问,所以 下面的 请求 无法访问。
http://localhost:5858/springmvc-1/WEB-INF/views/success.jsp
springmvc页面 能正常访问
http://localhost:5858/springmvc-1/helloworld
在index.jsp文件后面又新建了一个测试文件test1.jsp,发现能够正常访问。
http://localhost:5858/springmvc-1/test1.jsp
总结:在此web.xml配置的转发器的拦截域是:
经测试发现,先判断请求是不是 网站根目录/零层或多层路径/xxx.jsp,
如果是,查找是不是存在,存在的话就OK。不存在的就返回404
如果不是,那么再查看控制器,判断是否有匹配的映射名,如果仍没有就返回 404
补充:配置注解映射器和注解适配器
在配置转发器中,需要添加的注解映射器和注解适配器:
在spring3.1之前使用org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping注解映射器。
在spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping注解映射器。
在spring3.1之前使用org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter注解适配器。
在spring3.1之后使用org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter注解适配器。
下面是在 配置转发器【即前面提到的dispatcherServlet-servlet.xml】 中,进行编辑的内容:
<!-- 注解映射器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/> <!-- 注解的适配器 --> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> <!-- 使用 mvc:annotation-driven代替上边注解映射器和注解适配器配置 mvc:annotation-driven默认加载很多的参数绑定方法, 比如json转换解析器就默认加载了,如果使用mvc:annotation-driven不用配置上边的RequestMappingHandlerMapping和RequestMappingHandlerAdapter 实际开发时使用mvc:annotation-driven --> <!-- <mvc:annotation-driven></mvc:annotation-driven> -->
在实际使用时,不配置注解映射器和注解适配器,也能正常运行。因为MVC有默认配置在核心中的/org/springframework/web/servlet/DispatcherServlet.properties中,有兴趣的同学可以自行查看。
二、非注解情况配置
与注解情况的区别就是:1、修改handle 2、配置转发器文件
1、在springmvc.xml中的配置,如下:{也就是前面提到的dispatcherServlet-servlet.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-4.0.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"> <!-- 配置视图解析器【多个函数可选择】: 此解析器默认生成InternalResourceView,如果项目添加了jstl.jar包的话就会自动改为生成JstlView; 即如何把 handler 方法返回值解析为实际的物理视图,handler的返回值也可以具体是 /WEB-INF/XXXX/XXX.jsp,这样下面的试图解析器就不需要添加前缀和后缀了 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <!-- 配置jsp路径的前缀 --> <property name="prefix" value="/WEB-INF/views/"></property> <!-- 配置jsp路径的后缀 --> <property name="suffix" value=".jsp"></property> </bean> <!-- 配置handler --> <bean id="helloController" name="/hello" class="com.test.springmvc.handlers.HelloController"></bean> <!-- 处理器映射器 根据bean的name进行查找Handler 将controller 的url配置在bean的name中--> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean> <!-- 处理器适配器 通过查看源码,可知此适配器能执行实现Controller接口的handler:--> <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"></bean> </beans>
所有的映射器都实现HandlerMapping接口,所有的适配器都实现HandlerAdapter接口,还有另外一个非注解的适配器:org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter,另外一个映射器:org.springframework.web.servlet.handler.SimpleUrlHandlerMapping,如果这些都不配置的话,仍然能够使用,因为MVC有默认配置在核心中的/org/springframework/web/servlet/DispatcherServlet.properties中,有兴趣的同学可以自行查看。
2、配置handler【又叫controller】
package com.test.springmvc.handlers; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.ModelAndView; import org.springframework.web.servlet.mvc.Controller; //HelloController类必须实现Controller接口,查看映射文件: //这样,springmvc 才能识别它 public class HelloController implements Controller { @Override public ModelAndView handleRequest(HttpServletRequest request, HttpServletResponse response) throws Exception { //返回ModelAndView ModelAndView modelAndView = new ModelAndView(); //相当 于request的setAttribut,在jsp页面中通过itemsList取数据 //在当前的实验中, 我没有在网页中进行获取信息测试,所以设置了空值 modelAndView.addObject("itemsList", ""); //指定视图 下面这句有错误 (正确做法是在 转发配置页中 删除视图解析器的前缀和后缀) modelAndView.setViewName("/WEB-INF/views/success.jsp"); //或者另一种正确的做法 上面这句返回"success";保留 转发配置页中的视图解析器的前缀和后缀 //modelAndView.setViewName("success"); System.out.println("hello world" + request.toString()); request.toString(); return modelAndView; } }