Spring学习笔记(十二)

Spring MVC工作流程

Spring学习笔记(十二)

声明:图片来自网络,此处仅用于参考学习,不会用于商业用途

上图为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、发回响应给客户

Spring MVC配置

       (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值赋值给入参,参数同上

你可能感兴趣的:(spring,mvc)