zoukankan      html  css  js  c++  java
  • SpringMVC 入门程序

    SpringMVC是什么

    SpringMVC 是一种基于 Java 的实现 MVC 设计模型的请求驱动类型的轻量级 Web 框架,属于 Spring FrameWork 的后续产品,已经融合在 Spring Web Flow 里面。

    Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。

    使用 Spring 可插入的 MVC 架构,从而在使用 Spring 进行 WEB 开发时,可以选择使用 Spring 的 Spring MVC 框架或集成其他 MVC 开发框架,如 Struts1(现在一般不用),Struts2 等。

    SpringMVC 入门程序

    1. 导入依赖

        <properties>
            <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
            <maven.compiler.source>1.7</maven.compiler.source>
            <maven.compiler.target>1.7</maven.compiler.target>
            <!--版本锁定-->
            <spring.version>5.0.2.RELEASE</spring.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>junit</groupId>
                <artifactId>junit</artifactId>
                <version>4.11</version>
                <scope>test</scope>
            </dependency>
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-context</artifactId>
                <version>${spring.version}</version>
            </dependency>
    
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-web</artifactId>
                <version>${spring.version}</version>
            </dependency>
    
            <dependency>
                <groupId>org.springframework</groupId>
                <artifactId>spring-webmvc</artifactId>
                <version>${spring.version}</version>
            </dependency>
            <dependency>
                <groupId>javax.servlet</groupId>
                <artifactId>servlet-api</artifactId>
                <version>2.5</version>
                <scope>provided</scope>
            </dependency>
    
            <dependency>
                <groupId>javax.servlet.jsp</groupId>
                <artifactId>jsp-api</artifactId>
                <version>2.0</version>
                <scope>provided</scope>
            </dependency>
    
        </dependencies>

    2. 配置核心的控制器(配置DispatcherServlet) 

       在web.xml配置文件中核心控制器DispatcherServlet

    <!DOCTYPE web-app PUBLIC
     "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
     "http://java.sun.com/dtd/web-app_2_3.dtd" >
    
    <web-app>
      <display-name>Archetype Created Web Application</display-name>
    
      <!--配置SpringMVC的核心控制器DispatcherServlet-->
      <servlet>
        <servlet-name>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--配置Servlet的初始化参数, 读取Spring的配置文件, 创建Spring容器-->
        <init-param>
          <param-name>contextConfigLocation</param-name>
          <param-value>classpath:springConfig.xml</param-value>
        </init-param>
        <load-on-startup>1</load-on-startup>
      </servlet>
      <servlet-mapping>
        <servlet-name>dispatcherServlet</servlet-name>
        <url-pattern>/</url-pattern>
      </servlet-mapping>
    </web-app>

    3. 编写spring的配置文件springConfig.xml  并在其中   配置视图解析器  和  开启对注解MVC的支持

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
           xmlns:mvc="http://www.springframework.org/schema/mvc"
           xmlns:context="http://www.springframework.org/schema/context"
           xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
           xsi:schemaLocation="
           http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans.xsd
           http://www.springframework.org/schema/mvc
           http://www.springframework.org/schema/mvc/spring-mvc.xsd
           http://www.springframework.org/schema/context
           http://www.springframework.org/schema/context/spring-context.xsd">
        <!-- 配置spring创建容器时要扫描的包 -->
        <context:component-scan base-package="com.mkl"/>
    
        <!--配置视图解析器-->
        <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
            <property name="prefix" value="/WEB-INF/pages/"></property>
            <property name="suffix" value=".jsp"></property>
        </bean>
    
        <!--配置Spring开启注解MVC的支持-->
        <mvc:annotation-driven></mvc:annotation-driven>
    </beans>

    <mvc:annotation-driven>说明 :

    在 SpringMVC 的各个组件中,处理器映射器处理器适配器视图解析器称为 SpringMVC 的三大组件。

    使用<mvc:annotation-driven> 自动加载 RequestMappingHandlerMapping (处理映射器)和 RequestMappingHandlerAdapter ( 处 理 适 配 器 ) ,

    它就相当于在 xml 中配置了: 

    <!-- 上面的标签相当于 如下配置--> 
    <!-- Begin --> 
    
    <!-- HandlerMapping --> 
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"></bean>
    <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean> 
    
    <!-- HandlerAdapter --> 
    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"></bean> 
    <bean class="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter"></bean> 
    <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"></bean> 
    
    <!-- HadnlerExceptionResolvers --> 
    <bean class="org.springframework.web.servlet.mvc.method.annotation.ExceptionHandlerExceptionResolver"></bean> 
    <bean class="org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolver"></bean> 
    <bean class="org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver" ></bean> 
    <!-- End --> 

    4. 编写index.jsp和HelloController控制器类 

    index.jsp

    <body>        
    <h3>入门案例</h3>        
    <a href="hello">入门案例</a>
    </body>

    HelloController控制器类 

    //控制器类
    @Controller
    public class HelloController {
        @RequestMapping(path ="/hello")
        public String say(){
            System.out.println ("receive request!");
            return "success";
        }
    }

    5. 在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面

    入门案例的执行流程

      1. 当启动Tomcat服务器的时候,因为配置了load-on-startup标签,所以会创建DispatcherServlet对象, 就会加载springConfig.xml配置文件

      2. 开启了注解扫描,那么HelloController对象就会被创建

      3. 从index.jsp发送请求,请求会先到达DispatcherServlet核心控制器,根据配置@RequestMapping注解 找到执行的具体方法

      4. 根据执行方法的返回值,再根据配置的视图解析器,去指定的目录下查找指定名称的JSP文件

      5. Tomcat服务器渲染页面,做出响应

      入门案例中的组件分析  :

        1. 前端控制器(DispatcherServlet)

          用户请求到达前端控制器,它就相当于 mvc 模式中的 c,

          dispatcherServlet 是整个流程控制的中心,由 它调用其它组件处理用户的请求,

          dispatcherServlet 的存在降低了组件之间的耦合性。 

        2. 处理器映射器(HandlerMapping)

          HandlerMapping 负责根据用户请求找到 Handler 即处理器,

          SpringMVC 提供了不同的映射器实现不同的 映射方式,例如:配置文件方式,实现接口方式,注解方式等。 

        3. 处理器(Handler)

          它就是我们开发中要编写的具体业务控制器。

          由 DispatcherServlet 把用户请求转发到 Handler。由 Handler 对具体的用户请求进行处理。 

        4. 处理器适配器(HandlAdapter)

          通过 HandlerAdapter 对处理器进行执行,这是适配器模式的应用,通过扩展适配器可以对更多类型的处理器进行执行。 

        5. 视图解析器(View Resolver)

          View Resolver 负责将处理结果生成 View 视图,

          View Resolver 首先根据逻辑视图名解析成物理视图名 即具体的页面地址,

          再生成 View 视图对象,最后对 View 进行渲染将处理结果通过页面展示给用户。 

        6. 视图(View) 

          SpringMVC 框架提供了很多的 View 视图类型的支持,包括:jstlView、freemarkerView、pdfView 等。我们最常用的视图就是 jsp

    RequestMapping注解

    1. RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系

    2. RequestMapping注解可以作用在方法和类上

      1. 作用在类上:第一级的访问目录

      2. 作用在方法上:第二级的访问目录

      出现位置:

        类上:

          请求 URL 的第一级访问目录。

          此处不写的话,就相当于应用的根目录。

          写的话需要以/开头。

          它出现的目的是为了使我们的 URL 可以按照模块化管理:

          例如:

            账户模块:

              /account/add

              /account/update

              /account/delete ...

            订单模块:

              /order/add

              /order/update

              /order/delete

            红色的部分就是把 RequsetMappding 写在类上,使我们的 URL 更加精细。

        方法上:

          请求 URL 的第二级访问目录。

      3. 细节:路径可以不编写 / 表示应用的根目录开始

      4. 细节:

         <a href="${ pageContext.request.contextPath }/hello">入门案例</a>

        ${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /

    3. RequestMapping的属性

      1. path 指定请求路径的url

      2. value value属性和path属性是一样的

      3. mthod 指定该方法的请求方式 

        例如:method={RequestMethod.POST}

      4. params 指定限制请求参数的条件

        它支持简单的表达式。

        要求请求参数的 key 和 value 必须和 配置的一模一样。   

        例如:     

          params = {"accountName"},表示请求参数必须有 accountName     

          params = {"moeny!100"},表示请求参数中 money 不能是 100。 

      5. headers 发送的请求中必须包含的请求头

  • 相关阅读:
    poj2631 Roads in the North(求树的直径)
    P3809 【模板】后缀排序
    P3376 【模板】网络最大流dinic算法
    3224: Tyvj 1728 普通平衡树
    034 Android IntentService 的使用
    033 Android 绑定Service并与之通信
    032 Android Service
    031 Android 异步任务(AsyncTask)
    030 Android 线程+Handler的使用
    029 Android WebView的使用(用来显示网页)
  • 原文地址:https://www.cnblogs.com/mkl7/p/10794589.html
Copyright © 2011-2022 走看看