参考来源:http://blog.csdn.net/qq924862077/article/details/54286976?utm_source=gold_browser_extension

RequestToViewNameTranslator可以在处理器返回的View为空时使用它根据Request获取viewName。RequestToViewNameTranslator提供的实现类只有一个DefaultRequestToViewNameTranslator。

接口RequestToViewNameTranslator中定义的如下:提供了getViewName抽象方法,其实就是根据request请求获取来组装视图名称。

  1. public interface RequestToViewNameTranslator {
  2. /**
  3. * Translate the given {@link HttpServletRequest} into a view name.
  4. * @param request the incoming {@link HttpServletRequest} providing
  5. * the context from which a view name is to be resolved
  6. * @return the view name (or {@code null} if no default found)
  7. * @throws Exception if view name translation fails
  8. */
  9. String getViewName(HttpServletRequest request) throws Exception;
  10. }

其实现类DefaultRequestToViewNameTranslator中的实现如下:其实其简单实现就是将请求名称作为视图名称返回,逻辑还是比较简单的。

  1. @Override
  2. public String getViewName(HttpServletRequest request) {
  3. String lookupPath = this.urlPathHelper.getLookupPathForRequest(request);
  4. return (this.prefix + transformPath(lookupPath) + this.suffix);
  5. }

接下来我们看看RequestToViewNameTranslator在springMVC中的具体运行流程:

首先在DispatcherServlet的doDispatch函数中会设置默认的视图名

  1. protected void doDispatch(HttpServletRequest request, HttpServletResponse response) throws Exception {
  2. ......
  3. //设置默认的视图名称
  4. applyDefaultViewName(processedRequest, mv);
  5. ......
  6. }

在applyDefaultViewName中会判断ModelAndView的hasView为空时,就设置viewName

  1. private void applyDefaultViewName(HttpServletRequest request, ModelAndView mv) throws Exception {
  2. if (mv != null && !mv.hasView()) {
  3. mv.setViewName(getDefaultViewName(request));
  4. }
  5. }

getDefaultViewName的实现逻辑还是在ViewNameTranslator中。

  1. protected String getDefaultViewName(HttpServletRequest request) throws Exception {
  2. return this.viewNameTranslator.getViewName(request);
  3. }

在DefaultViewNameTranslator中实现的getViewName的逻辑如下,其实就是将请求路径作为ViewName

  1. @Override
  2. public String getViewName(HttpServletRequest request) {
  3. String lookupPath = this.urlPathHelper.getLookupPathForRequest(request);
  4. return (this.prefix + transformPath(lookupPath) + this.suffix);
  5. }

实现类DefaultViewNameTranslator的完整源码如下:

    1. public class DefaultRequestToViewNameTranslator implements RequestToViewNameTranslator {
    2. private static final String SLASH = "/";
    3. private String prefix = "";
    4. private String suffix = "";
    5. private String separator = SLASH;
    6. private boolean stripLeadingSlash = true;
    7. private boolean stripTrailingSlash = true;
    8. private boolean stripExtension = true;
    9. private UrlPathHelper urlPathHelper = new UrlPathHelper();
    10. public void setPrefix(String prefix) {
    11. this.prefix = (prefix != null ? prefix : "");
    12. }
    13. public void setSuffix(String suffix) {
    14. this.suffix = (suffix != null ? suffix : "");
    15. }
    16. public void setSeparator(String separator) {
    17. this.separator = separator;
    18. }
    19. public void setStripLeadingSlash(boolean stripLeadingSlash) {
    20. this.stripLeadingSlash = stripLeadingSlash;
    21. }
    22. public void setStripTrailingSlash(boolean stripTrailingSlash) {
    23. this.stripTrailingSlash = stripTrailingSlash;
    24. }
    25. public void setStripExtension(boolean stripExtension) {
    26. this.stripExtension = stripExtension;
    27. }
    28. public void setAlwaysUseFullPath(boolean alwaysUseFullPath) {
    29. this.urlPathHelper.setAlwaysUseFullPath(alwaysUseFullPath);
    30. }
    31. public void setUrlDecode(boolean urlDecode) {
    32. this.urlPathHelper.setUrlDecode(urlDecode);
    33. }
    34. public void setRemoveSemicolonContent(boolean removeSemicolonContent) {
    35. this.urlPathHelper.setRemoveSemicolonContent(removeSemicolonContent);
    36. }
    37. public void setUrlPathHelper(UrlPathHelper urlPathHelper) {
    38. Assert.notNull(urlPathHelper, "UrlPathHelper must not be null");
    39. this.urlPathHelper = urlPathHelper;
    40. }
    41. //根据请求获取视图名称
    42. @Override
    43. public String getViewName(HttpServletRequest request) {
    44. String lookupPath = this.urlPathHelper.getLookupPathForRequest(request);
    45. return (this.prefix + transformPath(lookupPath) + this.suffix);
    46. }
    47. protected String transformPath(String lookupPath) {
    48. String path = lookupPath;
    49. if (this.stripLeadingSlash && path.startsWith(SLASH)) {
    50. path = path.substring(1);
    51. }
    52. if (this.stripTrailingSlash && path.endsWith(SLASH)) {
    53. path = path.substring(0, path.length() - 1);
    54. }
    55. if (this.stripExtension) {
    56. path = StringUtils.stripFilenameExtension(path);
    57. }
    58. if (!SLASH.equals(this.separator)) {
    59. path = StringUtils.replace(path, SLASH, this.separator);
    60. }
    61. return path;
    62. }
    63. }

数据传递--------博客-----------springMVC源码分析--RequestToViewNameTranslator请求到视图名称的转换的更多相关文章

  1. springMVC源码分析--RequestToViewNameTranslator请求到视图名称的转换

    RequestToViewNameTranslator可以在处理器返回的View为空时使用它根据Request获取viewName.RequestToViewNameTranslator提供的实现类只 ...

  2. springMVC源码分析--DispatcherServlet请求获取及处理

    在之前的博客springMVC源码分析--容器初始化(二)DispatcherServlet中我们介绍过DispatcherServlet,是在容器初始化过程中出现的,我们之前也说过Dispatche ...

  3. springMVC源码分析--访问请求执行ServletInvocableHandlerMethod和InvocableHandlerMethod

    在之前一篇博客中springMVC源码分析--RequestMappingHandlerAdapter(五)我们已经简单的介绍到具体请求访问的执行某个Controller中的方法是在RequestMa ...

  4. springMVC源码分析--FlashMap和FlashMapManager重定向数据保存

    在上一篇博客springMVC源码分析--页面跳转RedirectView(三)中我们看到了在RedirectView跳转时会将跳转之前的请求中的参数保存到fFlashMap中,然后通过FlashMa ...

  5. springMVC源码分析--HandlerInterceptor拦截器调用过程(二)

    在上一篇博客springMVC源码分析--HandlerInterceptor拦截器(一)中我们介绍了HandlerInterceptor拦截器相关的内容,了解到了HandlerInterceptor ...

  6. springMVC源码分析--页面跳转RedirectView(三)

    之前两篇博客springMVC源码分析--视图View(一)和springMVC源码分析--视图AbstractView和InternalResourceView(二)中我们已经简单的介绍了View相 ...

  7. springMVC源码分析--视图AbstractView和InternalResourceView(二)

    上一篇博客springMVC源码分析--视图View(一)中我们介绍了简单介绍了View的结构实现及运行流程,接下来我们介绍一下View的实现类做的处理操作. AbstractView实现了rende ...

  8. springMVC源码分析--视图View(一)

    之前的博客springMVC源码分析--HttpMessageConverter数据转化(一)中我们已经介绍了数据返回值的处理,在博客springMVC源码分析--ViewResolver视图解析器( ...

  9. springMVC源码分析--HttpMessageConverter写write操作(三)

    上一篇博客springMVC源码分析--HttpMessageConverter参数read操作中我们已经简单介绍了参数值转换的read操作,接下来我们介绍一下返回值的处理操作.同样返回值的操作操作也 ...

随机推荐

  1. poj——2367  Genealogical tree

    Genealogical tree Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6025   Accepted: 3969 ...

  2. iis站点内存泄漏问题分析

    在一次上线过程中iis内存飙升,随后跟运维要到站点的dump文件,使用windbg分析了clr的内存分配,找到了问题的症结,先记录如下: 使用windbg加载dump文件 1.打开windbg,Fil ...

  3. NTKO在线office控件使用实例

    目录 1. NTKO在线office控件使用实例 1.1. 基础介绍 1.2. 基本原理 1.3. 实例 1.3.1. 打开.保存部分代码 1.3.2. 动态设值 1. NTKO在线office控件使 ...

  4. IOS开发之简单计算器

    用Object-C写的一个简单的计算机程序,主要学习按钮的action动作. 以下是主界面: 以下代码时界面按钮和ViewController.h连接的地方: - (IBAction)button_0 ...

  5. CCNA参考链接

    http://www.cisco.com/c/en/us/support/docs/lan-switching/vtp/10558-21.html http://www.cisco.com/c/en/ ...

  6. RHEL6.5上Oracle ACFS与Linux samba一起使用时遇到的bug

    RHEL上的Oracle ACFS与linux samba一起使用时遇到的bug 一.环境介绍: cat /etc/issue的结果为: Red Hat Enterprise Linux Server ...

  7. python爬虫实践

    模拟登陆与文件下载 爬取http://moodle.tipdm.com上面的视频并下载 模拟登陆 由于泰迪杯网站问题,测试之后发现无法用正常的账号密码登陆,这里会使用访客账号登陆. 我们先打开泰迪杯的 ...

  8. Tomcat 隐藏Server Name

    隐藏Http请求中的Header ServerName 方法一 在tomcat/lib/tomcat-coyote.jar中 下面两个文件 org/apache/coyote/http11/Const ...

  9. Enterprise Library 5.0 学习笔记

    近期了解了微软提供的企业开发框架Enterprise Library,眼下最新版本号是6.0,可是不支持FW3.5.所以就学习了5.0的版本号,EL5.0支持FW3.5和4.0,官网下载地址是:htt ...

  10. ppp点对点协议

    直接链接两个信令点的一组链路称作什么? PPP点到点连接: 点对点协议(PPP)为在点对点连接上传输多协议数据包提供了一个标准方法.PPP 最初设计是为两个对等节点之间的 IP 流量传输提供一种封装协 ...