SpringMVC视图转发重定向区别是什么


这篇文章主要介绍了SpringMVC视图转发重定向区别是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringMVC视图转发重定向区别是什么文章都会有所收获,下面我们一起来看看吧。SpringMVC 中的视图是 View 接口,视图的作用是渲染数据,将模型 Model 中的数据展示给用户。视图的种类很多,默认有:转发视图和重定向视图。若使用的视图技术为 Thymeleaf,在 SpringMVC 的配置文件中配置了 Thymeleaf 的视图解析器,由此视图解析器解析之后所得到的是 ThymeleafView。当控制器方法中所设置的视图名称没有任何前缀时,此时的视图名称会被 SpringMVC 配置文件中所配置的视图解析器解析。回顾下spring配置文件里的视图解析器的配置:视图名称拼接视图前缀视图后缀所得到的最终路径,会通过转发的方式实现跳转。之前写的代码示例一直都是这种,比如:SpringMVC中默认的转发视图是 InternalResourceView 。当控制器方法中所设置的视图名称以forward:为前缀时,创建 InternalResourceView 视图。此时的视图名称不会被 SpringMVC 配置文件中所配置的视图解析器解析,而是将前缀”forward:”去掉,剩余部分作为最终路径通过转发的方式实现跳转。控制器方法 testToForward 中,进行了转发forward:/testThymeleafView,去掉forward:之后,就可以转发到/testThymeleafView上。也就是说,当我访问 http://localhost:8080/springmvc/testToForward,应该跳转显示出 success 页。SpringMVC 中默认的重定向视图是 RedirectView 。当控制器方法中所设置的视图名称以redirect:为前缀时,创建 RedirectView 免费云主机域名视图。此时的视图名称不会被 SpringMVC 配置文件中所配置的视图解析器解析,而是会将前缀”redirect:”去掉,剩余部分作为最终路径通过重定向的方式实现跳转。继续新增一个控制器方法 testRedirect() 来测试一下:嗯?testToForward()testRedirect()最终都是访问/testThymeleafView,那这2个还不是一样?其实不一样。转发访问/testToForward时,页面看到的是 success 页面,浏览器地址栏仍然是/testToForward。重定向访问/testRedirect时,页面看到的是 success 页面,地址栏里也变成了/testThymeleafView。转发浏览器是发生一次请求,重定向是2次。转发可以获取请求域中的数据,但是重定向不可以。因为转发用到一次请求,也就是用到的request对象是同一个。重定向是发送2次请求,是2个request对象。转发可以访问 WEB-INF 中的资源,但是重定向不可以。因为 WEB-INF 下面的资源具有隐藏性,只能通过服务器内部来访问,不能通过浏览器来访问。转发不可以跨域,重定向可以。转发是发生在服务器内部的,就只能访问内部的资源。而浏览器发送了2次请求,通过浏览器可以访问任何资源,比如我重定向到百度首页。视图控制器实际上是 springMVC 配置文件里的一个标签,作用也是实现请求地址和视图页面的映射关系。当控制器方法中,仅仅用来实现页面跳转,即只需要设置视图名称时,可以将处理器方法使用view-controller标签进行表示。比如:这里就可以注释掉,在springmvc 配置文件中用视图控制器来配置。注意这里用的命名空间是 mvc,要去添加上。重新部署,访问http://localhost:8080/springmvc/:依然可以访问成功。但是当我点击 index 中的超链接的时候报错了404:这是因为当在配置文件中配置了 view-controller 之后,控制器中写的所有请求映射都失效了。还需要再加入一个配置,设置开启 mvc 注解驱动的标签:再次点击跳转,访问成功:关于“SpringMVC视图转发重定向区别是什么”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“SpringMVC视图转发重定向区别是什么”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注百云主机行业资讯频道。

相关推荐: html5支不支持boolean值属性

本篇内容介绍了“html5支不支持boolean值属性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! html5支持boolean值属性;boolean值属性指…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 05/07 19:33
下一篇 05/07 19:33

相关推荐