视图解析器
Themeleaf视图解析器
在SpringMVC.xml文件中配置themeleaf视图解析器,在返回值没有任何前缀的情况下,使用的是当前配置的视图解析器,themeleaf视图解析器实现的还是请求转发
@Controller
public class ViewController {
@RequestMapping("/themeleafView")
public String themeleafView(){
return "success";
}
}
请求转发视图解析器
SpringMVC中默认的转发视图是InternalResourceView,在SpringMVC中返回值的前缀是“forward:”,此视图不会被配置文件中的视图解析器解析,而是创建InternalResourceView视图,将前缀去掉,剩余的路径通过转发的方式跳转
这种视图解析器基本上不用,因为themeleaf视图解析器也是通过转发方式跳转
重定向视图解析器
重定向和请求转发的区别:重定向是两次请求,请求转发是一次请求,所以请求转发会带着request域中的数据。
SpringMVC中默认的重定向视图是redirectView,返回值的前缀为“redirect:”此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"redirect:"去掉,剩余部分作为最终路径通过重定向的方式实现跳转
通过以下代码看一下三种不同的视图解析器
通过下面的例子发现,无论是请求转发还是重定向都不可以直接访问资源
而用请求转发视图解析器跳转时浏览器的路径为:http://localhost:8080/SpringMVC_demo02/forwardView
使用重定向视图解析器跳转时浏览器的路径为:http://localhost:8080/SpringMVC_demo02/themeleafView
这就证明了我们上面所说的重定向是两次请求,第一次请求了/redirectView,第二次请求了themeleafView
@Controller
public class ViewController {
//使用themeleaf视图解析器
@RequestMapping("/themeleafView")
public String themeleafView(){
return "success";
}
//使用请求转发视图解析器
@RequestMapping("/forwardView")
public String forwardView(){
return "forward:/themeleafView";
}
//使用重定向视图解析器
@RequestMapping("/redirectView")
public String redirectView(){
return "redirect:/themeleafView";
}
}
<a th:href="@{themeleafView}">使用themeleaf视图解析器</a><br>
<a th:href="@{forwardView}">使用InternalResource视图解析器</a><br>
<a th:href="@{redirectView}">使用redirect视图解析器</a><br>
view-controller
view-controller标签适用于该请求中的内容只是为了返回页面,而不在其中添加其他多余代码
需要注意的是view-controller标签会使其他控制器的请求映射全部失效,此时需要在SpringMVC的核心配置文件中设置开启mvc注解驱动的标签
<!--
path:设置处理请求地址,相当于 @RequestMapping("/themeleafView") 括号中的值
view-name:设置请求地址所对应的视图名称,相当于返回值
-->
<mvc:view-controller path="/" view-name="index"></mvc:view-controller>
<!--开启mvc注解驱动-->
<mvc:annotation-driven/>