SpringMVC入门

1      SpringMVC入门

1.1    需求

实现商品查询列表功能。

 

1.2    开发环境准备

本教程使用Eclipse+tomcat7开发

 

详细参考“Eclipse开发环境配置-indigo.docx”文档

 

 

1.3    第一步:建立一个Web项目

在eclipse下创建动态web工程springmvc_first。

 

1.4    第二步:导入spring3.2.0的jar包

 

 

1.5    第三步:前端控制器配置

在WEB-INF\web.xml中配置前端控制器,

 

<servlet>

<servlet-name>springmvc</servlet-name>

<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>

<init-param>

<param-name>contextConfigLocation</param-name>

<param-value>classpath:springmvc.xml</param-value>

</init-param>

<load-on-startup>1</load-on-startup>

</servlet>

<servlet-mapping>

<servlet-name>springmvc</servlet-name>

<url-pattern>*.action</url-pattern>

</servlet-mapping>

 

 

load-on-startup:表示servlet随服务启动;

url-pattern:*.action的请交给DispatcherServlet处理。

contextConfigLocation:指定springmvc配置的加载位置,如果不指定则默认加

载WEB-INF/[DispatcherServlet的Servlet 名字]-servlet.xml。

 

1.5.1  Servlet拦截方式

1、拦截固定后缀的url,比如设置为 *.do、*.action, 例如:/user/add.action

此方法最简单,不会导致静态资源(jpg,js,css)被拦截。

 

2、拦截所有,设置为/,例如:/user/add  /user/add.action

此方法可以实现REST风格的url,很多互联网类型的应用使用这种方式。

但是此方法会导致静态文件(jpg,js,css)被拦截后不能正常显示。需要特殊处理。

 

3、拦截所有,设置为/*,此设置方法错误,因为请求到Action,当action转到jsp时再次被拦截,提示不能根据jsp路径mapping成功。

 

1.6    第四步:springmvc配置文件

 

Springmvc默认加载WEB-INF/[前端控制器的名字]-servlet.xml,也可以在前端控制器定义处指定加载的配置文件,如下:

 

<init-param>

<param-name>contextConfigLocation</param-name>

<param-value>classpath:springmvc.xml</param-value>

</init-param>

如上代码,通过contextConfigLocation加载classpath下的springmvc.xml配置文件。

 

1.7    第五步:配置处理器适配器

 

在springmvc.xml文件配置如下:

<bean    class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

 

SimpleControllerHandlerAdapter:即简单控制器处理适配器,所有实现了org.springframework.web.servlet.mvc.Controller 接口的Bean作为

Springmvc的后端控制器。

 

1.8    第六步:处理器开发

 

public class ItemList1 implements Controller {

 

    @Override

    public ModelAndView handleRequest(HttpServletRequest request,

           HttpServletResponse response) throws Exception {

      

       //商品列表

       List<Items> itemsList = new ArrayList<Items>();

      

       Items items_1 = new Items();

       items_1.setName("联想笔记本");

       items_1.setPrice(6000f);

       items_1.setDetail("ThinkPad T430 联想笔记本电脑!");

      

       Items items_2 = new Items();

       items_2.setName("苹果手机");

       items_2.setPrice(5000f);

       items_2.setDetail("iphone6苹果手机!");

      

       itemsList.add(items_1);

       itemsList.add(items_2);

      

        //创建modelAndView准备填充数据、设置视图

       ModelAndView modelAndView = new ModelAndView();

      

       //填充数据

       modelAndView.addObject("itemsList", itemsList);

       //视图

       modelAndView.setViewName("order/itemsList");

      

       return modelAndView;

    }

   

 

}

 

org.springframework.web.servlet.mvc.Controller:处理器必须实现Controller 接口。

ModelAndView:包含了模型数据及逻辑视图名

 

 

 

1.9    第七步:配置处理器映射器

 

在springmvc.xml文件配置如下:

 

<beans xmlns="http://www.springframework.org/schema/beans"

   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:mvc="http://www.springframework.org/schema/mvc"

   xmlns:context="http://www.springframework.org/schema/context"

   xmlns:aop="http://www.springframework.org/schema/aop"xmlns:tx="http://www.springframework.org/schema/tx"

   xsi:schemaLocation="http://www.springframework.org/schema/beans

      http://www.springframework.org/schema/beans/spring-beans-3.2.xsd

      http://www.springframework.org/schema/mvc

      http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd

      http://www.springframework.org/schema/context

      http://www.springframework.org/schema/context/spring-context-3.2.xsd

      http://www.springframework.org/schema/aop

      http://www.springframework.org/schema/aop/spring-aop-3.2.xsd

      http://www.springframework.org/schema/tx

      http://www.springframework.org/schema/tx/spring-tx-3.2.xsd">

 

   <!-- 处理器映射器 -->

   <!-- 根据beanname进行查找Handler actionurl配置在beanname -->

   <bean

      class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

 

BeanNameUrlHandlerMapping:表示将定义的Bean名字作为请求的url,需要将编写的controller在spring容器中进行配置,且指定bean的name为请求的url,且必须以.action结尾。

 

1.10       第八步:处理器配置

 

在springmvc.xml文件配置如下:

 

<!-- controller配置 -->

    <bean name="/items1.action"id="itemList1"

class="cn.itcast.springmvc.controller.first.ItemList1"/>   

 

name="/items1.action"前边配置的处理器映射器为BeanNameUrlHandlerMapping,如果请求的URL 为“上下文/items1.action”将会成功映射到ItemList1控制器。

 

 

1.11       第九步:配置视图解析器

 

在springmvc.xml文件配置如下:

 

<!--ViewResolver -->

<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">

<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>

<property name="prefix" value="/WEB-INF/jsp/"/>

<property name="suffix" value=".jsp"/>

</bean>

 

InternalResourceViewResolver:支持JSP视图解析

viewClass:JstlView表示JSP模板页面需要使用JSTL标签库,所以classpath中必须包含jstl的相关jar 包;

prefix 和suffix:查找视图页面的前缀和后缀,最终视图的址为:

前缀+逻辑视图名+后缀,逻辑视图名需要在controller中返回ModelAndView指定,比如逻辑视图名为hello,则最终返回的jsp视图地址 “WEB-INF/jsp/hello.jsp”

 

 

 

 

 

1.12       第十步:视图开发

 

创建/WEB-INF/jsp/order/itemsList.jsp视图页面:

 

<%@ page language="java"contentType="text/html; charset=UTF-8"

   pageEncoding="UTF-8"%>

<%@ taglib uri="http://java.sun.com/jsp/jstl/core"prefix="c" %>

<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt"  prefix="fmt"%>

<!DOCTYPE htmlPUBLIC "-//W3C//DTDHTML 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>查询商品列表</title>

</head>

<body>

商品列表:

<table width="100%"border=1>

<tr>

    <td>商品名称</td>

    <td>商品价格</td>

    <td>商品描述</td>

</tr>

<c:forEach items="${itemsList }"var="item">

<tr>

    <td>${item.name }</td>

    <td>${item.price }</td>

    <td>${item.detail }</td>

</tr>

</c:forEach>

 

</table>

</body>

</html>

 

 

 

1.13       第十一步:部署在tomcat测试

 

通过请求:http://localhost:8080/springmvc_first/items1.action,如果页面输出商品列表就表明我们成功了!

 

1.14       DispatcherServlet

         DispathcerServlet作为springmvc的中央调度器存在,DispatcherServlet创建时会默认从DispatcherServlet.properties文件加载springmvc所用的各各组件,如果在springmvc.xml中配置了组件则以springmvc.xml中配置的为准,DispatcherServlet的存在降低了springmvc各各组件之间的耦合度。

 

 

1.15       HandlerMapping处理器映射器

HandlerMapping 负责根据request请求找到对应的Handler处理器及Interceptor拦截器,将它们封装在HandlerExecutionChain 对象中给前端控制器返回。

 

1.15.1             BeanNameUrlHandlerMapping

         BeanNameUrl处理器映射器,根据请求的url与spring容器中定义的bean的name进行匹配,从而从spring容器中找到bean实例。

 

<!—beanName Url映射器 -->

<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>

 

 

 

1.15.2             SimpleUrlHandlerMapping

         simpleUrlHandlerMapping是BeanNameUrlHandlerMapping的增强版本,它可以将url和处理器bean的id进行统一映射配置。

<!—简单url映射 -->

    <bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">

       <property name="mappings">

           <props>

              <prop key="/items1.action">controller的bean id</prop>

              <prop key="/items2.action">controller的bean id</prop>

           </props>

       </property>

    </bean>

 

161    HandlerAdapter处理器适配器

       HandlerAdapter会根据适配器接口对后端控制器进行包装(适配),包装后即可对处理器进行执行,通过扩展处理器适配器可以执行多种类型的处理器,这里使用了适配器设计模式。

 

SimpleControllerHandlerAdapter简单控制器处理器适配器,所有实现了org.springframework.web.servlet.mvc.Controller 接口的Bean通过此适配器进行适配、执行。

 

适配器配置如下:

<beanclass="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

 

 

 

1.1.1  HttpRequestHandlerAdapter

HttpRequestHandlerAdapter,http请求处理器适配器,所有实现了org.springframework.web.HttpRequestHandler 接口的Bean通过此适配器进行适配、执行。

 

适配器配置如下:

<beanclass="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter"/>

 

Controller实现如下:

 

 

public class ItemList2 implements HttpRequestHandler {

 

    @Override

    public void handleRequest(HttpServletRequest request,

           HttpServletResponse response) throws ServletException,IOException {

 

       // 商品列表

       List<Items> itemsList = newArrayList<Items>();

 

       Items items_1 = new Items();

       items_1.setName("联想笔记本");

       items_1.setPrice(6000f);

       items_1.setDetail("ThinkPadT430 联想笔记本电脑!");

 

       Items items_2 = new Items();

       items_2.setName("苹果手机");

       items_2.setPrice(5000f);

       items_2.setDetail("iphone5  苹果手机!");

 

       itemsList.add(items_1);

       itemsList.add(items_2);

 

       // 填充数据

       request.setAttribute("itemsList", itemsList);

      

       // 视图

       request.getRequestDispatcher("/WEB-INF/jsp/order/itemsList.jsp").forward(request, response);

 

 

    }

 

}

 

从上边可以看出此适配器器的handleRequest方法没有返回ModelAndView,可通过response修改定义响应内容,比如返回json数据:

 

response.setCharacterEncoding("utf-8");

response.setContentType("application/json;charset=utf-8");

response.getWriter().write("json串");

 

 

1.2    注解映射器和适配器

1.2.1  Controller的代码

 

@Controller

public class ItemList3 {

 

    @RequestMapping("/queryItem.action")

    public ModelAndView queryItem() {

       // 商品列表

       List<Items> itemsList = newArrayList<Items>();

 

       Items items_1 = new Items();

       items_1.setName("联想笔记本");

       items_1.setPrice(6000f);

       items_1.setDetail("ThinkPadT430 联想笔记本电脑!");

 

       Items items_2 = new Items();

       items_2.setName("苹果手机");

       items_2.setPrice(5000f);

       items_2.setDetail("iphone6苹果手机!");

 

       itemsList.add(items_1);

       itemsList.add(items_2);

 

       // 创建modelAndView准备填充数据、设置视图

       ModelAndView modelAndView = new ModelAndView();

 

       // 填充数据

       modelAndView.addObject("itemsList", itemsList);

       // 视图

       modelAndView.setViewName("order/itemsList");

 

       return modelAndView;

    }

 

}

 

1.2.2 组件扫描器

         使用组件扫描器省去在spring容器配置每个controller类的繁琐。使用<context:component-scan自动扫描标记@controller的控制器类,配置如下:

 

<!-- 扫描controller注解,多个包中间使用半角逗号分隔 -->

    <context:component-scan base-package="cn.itcast.springmvc.controller.first"/>

 

 

1.2.3  RequestMappingHandlerMapping

         注解式处理器映射器,对类中标记@ResquestMapping的方法进行映射,根据ResquestMapping定义的url匹配ResquestMapping标记的方法,匹配成功返回HandlerMethod对象给前端控制器,HandlerMethod对象中封装url对应的方法Method。

 

从spring3.1版本开始,废除了DefaultAnnotationHandlerMapping的使用,推荐使用RequestMappingHandlerMapping完成注解式处理器映射。

 

配置如下:

 

<!--注解映射器 -->

    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>

  

 

注解描述:

@RequestMapping定义请求url到处理器功能方法的映射

 

 

1.2.4  RequestMappingHandlerAdapter

注解式处理器适配器,对标记@ResquestMapping的方法进行适配。

 

从spring3.1版本开始,废除了AnnotationMethodHandlerAdapter的使用,推荐使用RequestMappingHandlerAdapter完成注解式处理器适配。

 

配置如下:

<!--注解适配器 -->

    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

 

1.2.5 <mvc:annotation-driven>

springmvc使用<mvc:annotation-driven>自动加载RequestMappingHandlerMapping和RequestMappingHandlerAdapter,可用在springmvc.xml配置文件中使用<mvc:annotation-driven>替代注解处理器和适配器的配置。

 

 

1.16       HandlerAdapter处理器适配器

       HandlerAdapter会根据适配器接口对后端控制器进行包装(适配),包装后即可对处理器进行执行,通过扩展处理器适配器可以执行多种类型的处理器,这里使用了适配器设计模式。

 

1.16.1             SimpleControllerHandlerAdapter

SimpleControllerHandlerAdapter简单控制器处理器适配器,所有实现了org.springframework.web.servlet.mvc.Controller 接口的Bean通过此适配器进行适配、执行。

 

适配器配置如下:

<beanclass="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>

 

 

 

1.16.2             HttpRequestHandlerAdapter

HttpRequestHandlerAdapter,http请求处理器适配器,所有实现了org.springframework.web.HttpRequestHandler 接口的Bean通过此适配器进行适配、执行。

 

适配器配置如下:

<beanclass="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter"/>

 

Controller实现如下:

 

public class ItemList2 implements HttpRequestHandler {

 

    @Override

    public void handleRequest(HttpServletRequest request,

           HttpServletResponse response) throws ServletException,IOException {

 

       // 商品列表

       List<Items> itemsList = newArrayList<Items>();

 

       Items items_1 = new Items();

       items_1.setName("联想笔记本");

       items_1.setPrice(6000f);

       items_1.setDetail("ThinkPadT430 联想笔记本电脑!");

 

       Items items_2 = new Items();

       items_2.setName("苹果手机");

       items_2.setPrice(5000f);

       items_2.setDetail("iphone5  苹果手机!");

 

       itemsList.add(items_1);

       itemsList.add(items_2);

 

       // 填充数据

       request.setAttribute("itemsList", itemsList);

      

       // 视图

       request.getRequestDispatcher("/WEB-INF/jsp/order/itemsList.jsp").forward(request, response);

 

 

    }

 

}

 

从上边可以看出此适配器器的handleRequest方法没有返回ModelAndView,可通过response修改定义响应内容,比如返回json数据:

 

response.setCharacterEncoding("utf-8");

response.setContentType("application/json;charset=utf-8");

response.getWriter().write("json串");

 

 

1.17       注解映射器和适配器

1.17.1             Controller的代码

 

@Controller

public class ItemList3 {

 

    @RequestMapping("/queryItem.action")

    public ModelAndView queryItem() {

       // 商品列表

       List<Items> itemsList = newArrayList<Items>();

 

       Items items_1 = new Items();

       items_1.setName("联想笔记本");

       items_1.setPrice(6000f);

       items_1.setDetail("ThinkPadT430 联想笔记本电脑!");

 

       Items items_2 = new Items();

       items_2.setName("苹果手机");

       items_2.setPrice(5000f);

       items_2.setDetail("iphone6苹果手机!");

 

       itemsList.add(items_1);

       itemsList.add(items_2);

 

       // 创建modelAndView准备填充数据、设置视图

       ModelAndView modelAndView = new ModelAndView();

 

       // 填充数据

       modelAndView.addObject("itemsList", itemsList);

       // 视图

       modelAndView.setViewName("order/itemsList");

 

       return modelAndView;

    }

 

}

 

1.17.2             组件扫描器

         使用组件扫描器省去在spring容器配置每个controller类的繁琐。使用<context:component-scan自动扫描标记@controller的控制器类,配置如下:

 

<!-- 扫描controller注解,多个包中间使用半角逗号分隔 -->

    <context:component-scan base-package="cn.itcast.springmvc.controller.first"/>

 

 

1.17.3             RequestMappingHandlerMapping

         注解式处理器映射器,对类中标记@ResquestMapping的方法进行映射,根据ResquestMapping定义的url匹配ResquestMapping标记的方法,匹配成功返回HandlerMethod对象给前端控制器,HandlerMethod对象中封装url对应的方法Method。

 

从spring3.1版本开始,废除了DefaultAnnotationHandlerMapping的使用,推荐使用RequestMappingHandlerMapping完成注解式处理器映射。

 

配置如下:

 

<!--注解映射器 -->

    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>

  

 

注解描述:

@RequestMapping定义请求url到处理器功能方法的映射

 

 

1.17.4             RequestMappingHandlerAdapter

注解式处理器适配器,对标记@ResquestMapping的方法进行适配。

 

从spring3.1版本开始,废除了AnnotationMethodHandlerAdapter的使用,推荐使用RequestMappingHandlerAdapter完成注解式处理器适配。

 

配置如下:

<!--注解适配器 -->

    <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

 

1.17.5             <mvc:annotation-driven>

springmvc使用<mvc:annotation-driven>自动加载RequestMappingHandlerMapping和RequestMappingHandlerAdapter,可用在springmvc.xml配置文件中使用<mvc:annotation-driven>替代注解处理器和适配器的配置。

 

1.18       springmvc处理流程源码分析

 

1.        用户发送请求到DispatherServlet前端控制器

2.        DispatherServlet调用HandlerMapping(处理器映射器)根据url查找Handler

     

3.        DispatherServlet调用HandlerAdapter(处理器适配器)对HandlerMapping找到Handler进行包装、执行。HandlerAdapter执行Handler完成后,返回了一个ModleAndView(springmvc封装对象)

 

           DispatherServlet找一个合适的适配器:

   

           适配器执行Hanlder

       

4.        DispatherServlet拿着ModelAndView调用ViewResolver(视图解析器)进行视图解析,解析完成后返回一个View(很多不同视图类型的View)

 

视图解析:


5.        DispatcherServlet进行视图渲染,将Model中数据放到request域,在页面展示


将model数据放在request域:

 


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringMVC是一个基于Java的Web框架,可以帮助我们快速地构建Web应用程序。下面是一个简单的SpringMVC入门示例,让你了解如何编写一个SpringMVC应用程序。 1. 创建Maven项目 首先,我们需要创建一个Maven项目。在Eclipse或者IntelliJ IDEA中,选择创建一个Maven项目,并添加SpringMVC依赖。 2. 配置web.xml 在web.xml文件中,我们需要配置DispatcherServlet。DispatcherServlet是SpringMVC的核心组件,它拦截所有的请求并将它们分发给相应的控制器。 ```xml <web-app> <display-name>Spring MVC Application</display-name> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/dispatcherServlet-servlet.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> ``` 在这个配置中,我们将DispatcherServlet的URL模式设置为"/",这意味着它将拦截所有的请求。contextConfigLocation参数指定了Spring配置文件的路径。 3. 配置dispatcherServlet-servlet.xml 在dispatcherServlet-servlet.xml文件中,我们需要配置SpringMVC相关的组件,例如控制器、视图解析器等等。 ```xml <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.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <context:component-scan base-package="com.example.controller" /> <mvc:annotation-driven /> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/" /> <property name="suffix" value=".jsp" /> </bean> </beans> ``` 在这个配置中,我们使用<context:component-scan>扫描了我们的控制器所在的包。我们还使用<mvc:annotation-driven>启用了SpringMVC注解驱动,并使用<bean>配置了一个视图解析器,将逻辑视图名映射为物理视图。 4. 编写控制器 ```java @Controller public class HelloController { @RequestMapping("/") public String hello() { return "hello"; } } ``` 在这个示例中,我们编写了一个控制器,使用@RequestMapping注解将"/"映射到hello()方法。hello()方法返回一个字符串"hello",这代表逻辑视图名。当DispatcherServlet收到一个请求并且URL匹配"/"时,它将会调用hello()方法,然后将逻辑视图名"hello"映射为物理视图名"/WEB-INF/views/hello.jsp"。 5. 编写视图 在"/WEB-INF/views/"目录下创建一个名为"hello.jsp"的JSP文件。 ```html <!DOCTYPE html> <html> <head> <title>Hello SpringMVC</title> </head> <body> <h1>Hello SpringMVC</h1> </body> </html> ``` 6. 运行应用程序 将应用程序部署到一个Web服务器上,并访问"http://localhost:8080/",你应该会看到一个"Hello SpringMVC"的页面。 以上就是一个简单的SpringMVC入门示例,希望能帮助你快速入门SpringMVC框架。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值