6 SpringMVC的视图
SpringMVC中的视图是View接口,视图的作用渲染数据,将模型Model中的数据展示给用户。SpringMVC视图的种类很多,默认有转发视图和重定向视图,若使用的视图技术为Thymeleaf,在SpringMVC的配置文件中配置了Thymeleaf的视图解析器,由此视图解析器解析之后所得到的是ThymeleafView。
知识点回顾:
1、请求转发(forward):
浏览器只发送一次请求,服务器再转发一次地址,最后地址栏是原先的地址。
可以获取请求域(request)中的数据
可以访问WEB-INF下的内容
不能跨域(我们自己的工程不能访问去什么百度、淘宝)
2、重定向(redirect):
浏览器发送两次请求,最后地址栏是重定向的地址。
不可以获取请求域(request)中的数据
不可以访问WEB-INF下的内容
能跨域(能访问百度、淘宝等等其他不属于我们工程的网站)
6.1 ThymeleafView
当控制器方法中所设置的视图名称没有任何前缀时 ,此时的视图名称会被SpringMVC配置文件中所配置的视图解析器解析 ,视图名称拼接视图前缀和视图后缀所得到的最终路径,会通过转发 的方式实现跳转。
此时新建一个viewController类,并且增加一个测试ThymeleafView的控制器类:
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class viewController {
@RequestMapping("/testThymeleafView")
public String testThymeleafView(){
return "success";
}
}
同时新增一个test_view页面,在此页面中添加超链接,使得测试更加方便
<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.Thymeleaf.org">
<head>
<meta charset="UTF-8">
<title>测试视图</title>
</head>
<body>
<a th:href="@{/testThymeleafView}">测试ThymeleafView</a><br>
</body>
</html>
增加完页面后,我们同时需要在ViewController类中增加控制器方法来请求映射到我们页面
做完这些后启动我们的服务器:
点击链接后实现跳转
6.2 转发视图
SpringMVC中默认的转发视图是InternalResourceView
SpringMVC中创建转发视图的情况:
当控制器方法中所设置的视图名称以"forward:"为前缀时 ,创建InternalResourceView视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"forward:"去掉,剩余部分作为最终路径通过转发的方式实现跳转
例如"forward:/",“forward:/employee”
在ViewCOntroller类中增加testForward方法进行测试:
@RequestMapping("/testForward")
public String testForward(){
//通过转发回到首页
return "forward:/";
}
同时在test_view页面中增加相应的超链接方便我们的测试
<a th:href="@{/testForward}">测试Forward</a><br>
做完这些后,重启服务器,点击相应的超链接,实现跳转,结果如下图
虽然页面通过转发跳转到的是首页,但是地址栏中的地址却是我们超链接原本的地址。
验证Forward能否进跨域:
增加一个控制器方法:
@RequestMapping("/tobaidu")
public String tobaidu(){
//通过转发回到首页
return "forward:https://www.baidu.com";
}
同时增加超链接,来对应该控制器方法:
6.3 重定向视图
SpringMVC中默认的重定向视图是RedirectView
当控制器方法中所设置的视图名称以"redirect:"为前缀时 ,创建RedirectView视图,此时的视图名称不会被SpringMVC配置文件中所配置的视图解析器解析,而是会将前缀"redirect:"去掉,剩余部分作为最终路径通过重定向的方式实现跳转
例如"redirect:/",“redirect:/employee”
增加控制器方法以及它对应的超链接进行测试:
@RequestMapping("/testRedirect")
public String testRedirect(){
//通过重定向访问首页
return "redirect:/";
}
结果如下,发现页面与地址均是首页
验证Redircet能否进行跨域访问
增加相应的控制器方法与其对应的超链接
@RequestMapping("/tobaidu1")
public String tobaidu1(){
//通过转发回到首页
return "redirect:https://www.baidu.com";
}
<a th:href="@{/tobaidu1}">测试Forward来跨域访问百度</a><br>
结果如下:成功到达百度页面
6. 4 视图控制器view-controller
当控制器方法中,仅仅用来实现页面跳转 ,即只需要设置视图名称时,可以将处理器方法使用view-controller标签进行表示
此时注释掉我们最开始的view控制器方法:
然后在sprngMVC.xml配置文件中增加以下内容:
<mvc:view-controller path="/view" view-name="test_view"></mvc:view-controller>
<!--开启mvc的注解驱动,如果不开启,使用view-controller便签会使其他控制器中的请求映射将全部失效-->
<mvc:annotation-driven />
此时还是能够正常访问到/view
页面