上一章节中首先讲解前端控制器DispatcherServlet的配置包括加载springmvc文件、拦截什么样的请求等
还有两个组件:分别是适配器和映射器(另外再补充一组)

非注解的处理器映射器 处理器映射器:
org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping
另一个映射器:
org.springframework.web.servlet.handler.SimpleUrlHandlerMapping
补充:多个映射器可以并存,前端控制器判断url能让哪些映射器映射,就让正确的映射器处理。
非注解的处理器适配器:
org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter 要求编写的Handler实现 Controller接口。
org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter 要求编写的Handler实现 HttpRequestHandler接口。

可能有人没有配置上面的那些发现程序能够运行。那么知识点来了:
本章的第一个知识点在一个配置文件中是springmvc框架里面的一个配置文件,它的作用就是当没有配置上面的适配器和处理器框架会根据这个文件默认使用一组适配器和映射器。

我们来简单的看下这个文件里面的内容:

要先看下面这个翻译:
# Default implementation classes for DispatcherServlet's strategy interfaces.
# Used as fallback when no matching beans are found in the DispatcherServlet context.
# Not meant to be customized by application developers.
org.springframework.web.servlet.LocaleResolver=org.springframework.web.servlet.i18n.AcceptHeaderLocaleResolver
org.springframework.web.servlet.ThemeResolver=org.springframework.web.servlet.theme.FixedThemeResolver
这个就是默认加载的处理器映射器有两个:第一个是根据Bean的名字URL的映射器,第二个是默认的注解处理器映射器(等下会讲注解的)
org.springframework.web.servlet.HandlerMapping=
org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping,
\ org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping
这个是默认加载的处理器适配器有三个:http请求相关的、简单的处理器适配器、默认的注解处理器适配器(等下会说到注解的)
org.springframework.web.servlet.HandlerAdapter=org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter,
\ org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter,
\ org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter org.springframework.web.servlet.HandlerExceptionResolver=
org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerExceptionResolver,
\ org.springframework.web.servlet.mvc.annotation.ResponseStatusExceptionResolver,
\ org.springframework.web.servlet.mvc.support.DefaultHandlerExceptionResolver org.springframework.web.servlet.RequestToViewNameTranslator=org.springframework.web.servlet.view.DefaultRequestToViewNameTranslator
org.springframework.web.servlet.ViewResolver=org.springframework.web.servlet.view.InternalResourceViewResolver
org.springframework.web.servlet.FlashMapManager=org.springframework.web.servlet.support.SessionFlashMapManager

上面的文件里面涉及到两个注解的组件分别是:

注解的处理器映射器
org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping
注解的处理器适配器 org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter
这个两个是在spring3.1版本之前用的,在3.1之后使用的都是和http请求相关的两个组件
分别是:
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping注解映射器。
org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter注解适配器。

程序配置:注解的这个两个必须成对出现,要么全部出现、要么都不出现

<!-- 知识点二:=========注解映射器====================== -->
<!-- 说明 :对类中标记@ResquestMapping的方法进行映射,根据ResquestMapping定义的url匹配-->
<!-- ResquestMapping标记的方法,匹配成功返回HandlerMethod对象给前端控制器,HandlerMethod对象中封装url对应的方法Method。 -->
<!-- 注意:从spring3.1版本开始,废除了DefaultAnnotationHandlerMapping的使用,推荐使用RequestMappingHandlerMapping完成注解式处理器映射。 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/>
<!-- 知识点三:=========注解适配器====================== -->
<!-- 说明:注解式处理器适配器,对标记@ResquestMapping的方法进行适配。-->
<!-- 从spring3.1版本开始,废除了AnnotationMethodHandlerAdapter的使用,推荐使用RequestMappingHandlerAdapter完成注解式处理器适配。 -->
<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/>

实时程序:

@Controller
public class ItemList3 {
@RequestMapping("/queryItem")
public ModelAndView queryItem() {
// 商品列表
List<Items> itemsList = new ArrayList<Items>();
Items items_2 = new Items();
items_2.setName("苹果手机");
items_2.setPrice(6088f);
items_2.setDetail("iphone6s苹果手机!");
itemsList.add(items_2);
// 创建modelAndView:填充数据、设置视图
ModelAndView modelAndView = new ModelAndView();
// 填充数据
modelAndView.addObject("itemsList", itemsList);// 类似request.setAttribute("","")
modelAndView.addObject("message", "Hello World!");
// 视图:逻辑名称
modelAndView.setViewName("/itemsList");// request.getRequestDispatcher("url").forward(request,// response);
return modelAndView;
}
}

当然光配置上面两个注解相关的组件还是不够的为什么呢?因为spring容器并不知道哪些类是处理器,这时候需要一个配置来把处理器交给容器管理。
知识点四:

<!-- 组件扫描器:可以扫描@Controller、@Service、@Repository等等 -->
<context:component-scan base-package="com.springapp.web.controller"/>

那么可能还有点懒说配置那两个注解相关的组件还是不方便,还是得写那么长。框架又帮我们想好了。
知识点五:真实开发的时候使用下面的配置可以代替上面配置的两个注解的组件

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

这样以后这个配置文件中只要配置如下内容就可以了:
没有使用注解时候的配置文件:

<?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: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 ">
<!-- 配置简单的控制器处理适配器 -->
<!-- SimpleControllerHandlerAdapter:即简单控制器处理适配器, -->
<!-- 所有实现了org.springframework.web.servlet.mvc.Controller 接口的Bean作为Springmvc的后端控制器。 -->
<bean
class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter" />
<bean class="org.springframework.web.servlet.mvc.HttpRequestHandlerAdapter" />
<!-- 配置BeanNameUrl处理器映射器 -->
<!-- BeanNameUrlHandlerMapping:表示将定义的Bean名字作为请求的url,需要将编写的controller在spring容器中进行配置, -->
<!-- 且指定bean的name为请求的url,且必须以.action结尾。 -->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping" />
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping" />
<!-- controller配置 -->
<!-- name="/items1.action":前边配置的处理器映射器为BeanNameUrlHandlerMapping, -->
<!-- 如果请求的URL 为“上下文/items1.action”将会成功映射到ItemList1控制器。 -->
<bean name="/items1.action" id="itemList1"
class="com.springapp.web.controller.ItemList1" />
<bean name="/items2.action" id="itemList2"
class="com.springapp.web.controller.ItemList2" />
<!-- 配置视图解析器 --> <!-- InternalResourceViewResolver:支持JSP视图解析 -->
<!-- viewClass:JstlView表示JSP模板页面需要使用JSTL标签库,所以classpath中必须包含jstl的相关jar包; -->
<!-- prefix 和suffix:查找视图页面的前缀和后缀,最终视图的址为: -->
<!-- 前缀+逻辑视图名+后缀,逻辑视图名需要在controller中返回ModelAndView指定,比如逻辑视图名为hello, -->
<!-- 则最终返回的jsp视图地址 "WEB-INF/jsp/hello.jsp" -->
<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>
</beans>

使用注解之后的配置文件:

<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 "> <!-- ======================组件扫描器====================== -->
<context:component-scan base-package="com" /> <!-- springmvc使用<mvc:annotation-driven> -->
<!-- 自动加载RequestMappingHandlerMapping和RequestMappingHandlerAdapter, -->
<!-- 使用<mvc:annotation-driven>替代注解处理器和适配器的配置。 -->
<mvc:annotation-driven /> <!-- 配置视图解析器 -->
<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> </beans>

作者: HansonQ
链接:http://www.imooc.com/article/4293
来源:慕课网

最新文章

  1. [翻译] ORMLite document -- Getting Started
  2. oracle 报警日志详解
  3. Ubuntu下tftp服务器的搭建
  4. VS2010 &quot;error MSB8011” 解决方法
  5. shell运行报 too many arguments错误
  6. cocos2d-x 动画特效集合
  7. Epub2基础知识介绍
  8. 数据结构(主席树):HDU 4729 An Easy Problem for Elfness
  9. 查询某库所有表的rows &amp;查看当前sql的注册信息
  10. java内存管理简析
  11. 官网下载qt-opensource-windows-x86-mingw482_opengl-5.3.1.exe。封装好了Qt libraries、Qt Creator。只需要这一个可执行程序就好了。
  12. cshtml一二
  13. jsp的开发模式
  14. My SQL 登录命令,创建表与删除表
  15. 多个RestTemplate对象示例
  16. Java的内存泄露
  17. 【算法】Normalization
  18. gitlab汉化
  19. servlet web.xml配置选项详解
  20. Redis简介+常用命令

热门文章

  1. 记一次CSR上线及总结
  2. 使用ruby搭建简易的http服务和sass环境
  3. SharePoint 2013 &ndash; Workflow Manager 1.0 offline download
  4. 【读书笔记】iOS-ASIHTTPRequest框架的使用。
  5. Base64与Bitmap转换
  6. IOS开发之自动布局--VFL语言
  7. TinyFox v2.3.2 正式发布,跨平台的.NET OWIN WEB服务器
  8. composer 学习资料
  9. JavaWeb 的学习一
  10. SQL挑战&mdash;&mdash;如何高效生成编码