声明:图片来自网络,此处仅用于参考学习,不会用于商业用途
上图为Spring MVC最基本的流程,并没有考虑拦截器等等流程的影响,后面将补充。
1、Dispatcher Servlet接收到客户的请求
2、Dispatcher Servlet通过Handler Mapping找到请求url对应的Controller
3、通过HandlerAdapter调用对应Controller的方法进行处理
4、Controller方法处理后返回ModelAndView对象到Dispatcher Servlet
5、Dispatcher Servlet再将ModelAndView中view的信息交由ViewResolver处理,ViewResolver处理后返回真正的View地址
6、Dispatcher Servlet将Model的信息交给View进行渲染
7、发回响应给客户
(1) web.xml中的配置:
<servlet> <servlet-name>spring</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>com.nstechs.commerce.AppConfig</param-value> </init-param> <!-- use annotation replace xml configuration. @Configuration class is required. --> <init-param> <param-name>contextClass</param-name> <param-value>org.springframework.web.context.support.AnnotationConfigWebApplicationContext</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>spring</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping>
上面是基于Annotation零配置的配置方法,传统的配置contextConnfigLoction值是配置文件的位置,不填会默认的去找WEB-INFO下的[servlet-name]-servlet.xml,如上面的代码就会找WEB-INFO下spring-servlet.xml。而contextClass属性值相当于Spring MVC配置文件中配置了:
<context:annotation-config />
启用Spring MVC 的注解。
(2.1)基于配置文件的Spring MVC 配置:
<?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:p="http://www.springframework.org/schema/p" xmlns:context="http://www.springframework.org/schema/context" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/context <a href="http://www.springframework.org/schema/context/spring-context-3.0.xsd">http://www.springframework.org/schema/context/spring-context-3.0.xsd</a>"> <!-- 启用spring mvc 注解 --> <context:annotation-config /> <!-- 设置使用注解的类所在的jar包 --> <context:component-scan base-package="controller"></context:component-scan> <!-- 完成请求和注解POJO的映射 --> <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" /> <!-- 对转向页面的路径解析。prefix:前缀, suffix:后缀 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver" p:prefix="/ jsp/" p:suffix=".jsp" /> </beans>
(2.2)基于Annotation的配置类
@Configuration @ComponentScan(basePackages={"controller"}) public class AppConfig{ @Bean public ViewResolver viewResolver() { InternalResourceViewResolver resolver = new InternalResourceViewResolver(); resolver.setPrefix("/jsp/"); resolver.setSuffix(".jsp"); return resolver; } }
与上面的配置文件效果相同
(3)Cotroller类用@Controller注解标识,Service用@Service注解标识,DAO类用@Repository注解标识,上面的配置文件/类中有配置扫描的包,只有包含上面注解的类,在设置的包中或子包中都会被识别为一个Bean加入Spring容器中。
(3.1)Controller类中在方法前使用@RequestMapping映射url和处理方法,Controller类上也可以使用
@RequestMapping属性:
method:用来限定Http请求的请求方法,值为RequestMethod枚举值集合,支持REST风格可以用RequestMethod.DELETE和RequestMethod.PUT(非必填,不填默认支持GET、POST、DELETE、PUT,实际上现在大多数的浏览器只支持GET和POST方法,Spring3.0提供了HiddenHttpMethodFilter,允许通过"_method"表单参数指定特殊Http请求方法,实际上还是用POST提交的)
value:映射的url数组(必填)url可以使用/user/*/createUser,*匹配一个不含/字符串不能为空,如/user/aaa/createUser;/user/**/createUser,匹配/user/aa/bb/createUser或直接/user/createUser;/user/createUser??,匹配两个字符;/user/{userId}可以捕获/user/123这样的url后面的字符串,再方法的入参前使用@PathVariable("userId")可以将捕获的值赋值给入参;
params:限定Http请求中参数,如@RequestMapping(value="/user" params="param1=value1")表示映射params含有param1=value1,链接有/user的http请求,其他用法params="param1"必须包含param1,params="!param1"不能含有param1,params="param1!=value1"
headers:限定Http请求头的值,设置规则与上面相似
@RquestParam、@RequestHeader、@PathVariable、@CookieValue为入参赋值
@RequestMapping(value="/user/{userId}") public String handleParam(@RequestParam("userName") String userName, @RequestHeader("Accept-Language" String language), @PathVariable("userId") Integer userId, @CookieValue("JSESSIONID") String sessionId) { return "success"; }
@RquestParam用于将Http请求中指定参数值赋值给入参
参数 :
value 值为参数名
required 值为boolean是否必须有值,为null时会抛出异常
defaultValue设置默认值,设置了会默认将required设置为false,当值为null时会使用默认值
@RequestHeader用于将Http请求中指定请求头值赋值给入参,参数同上
@PathVariable用于捕获url中对应值赋值给入参
@CookieValue用于将Http请求中指定cookie值赋值给入参,参数同上