SpringMVC学习笔记之视图

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页面
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

孤独的偷学者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值