zoukankan      html  css  js  c++  java
  • springmvc中的视图模型的返回方式

    way1:略过;

    way2:(神似way1)通过在方法的参数中添加一个Model类型的参数,,该参数由spring自动生成传入,

    然后在方法内部使用addAttribute()方式添加模型数据,

    最后使用return返回一个视图名称(视图的路径),

    从而在页面上可以同时使用模型数据以及得到视图页面.

    way3:当方法没有返回值时,此时请求该方法的资源路径将成为视图的路径,

        当时由于是直接从外部访问,因此该方式无法访问位于WEB-INF内的资源,同时资源也无法加上后缀名....不爽!!!

        具体如下图:

        

          way 3中的问题的解决方案:在springmvc的包里面有一个DispatcherServlet.properties的文件,其中有

        org.springframework.web.servlet.ViewResolver=org.springframework.web.servlet.view.InternalResourceViewResolver这一个配置,其为默认的视图解析

        器,,此时我们需要对其进行自定义的配置,,由该视图解析器对应的类InternalResourceViewResolver所继承的父类UrlBasedViewResolver中有两个前后缀的属性,,我们在

        ApplicationContext中对此2个前后缀进行重新配置,将前缀自定义为WEB-INF,而后缀自定义为.jsp,,这样在方法中返回的视图名称就只需写中间的部分,即可正常访问带后

        缀名的文件资源了.具体配置如下图:

        

        具体方法如下:

        

        以上仍然存在缺点:又如何访问位于web-inf外部的资源,以及如何自定义资源的访问方式是时转发(forward)还是重定向(redirect)????

          解决方法:在每个资源视图名称前加上forward或redirect前缀,即可实现自定义是采用转发还是重定向的方法方式....

          [注]:此时,后面的视图名称必须是一个完整的路径..

          

          加redirect前缀的实例如下:

              此时,方法中不用Model类型的对象了,因为是重定向....也只能访问web-inf外部的资源..

          

        

  • 相关阅读:
    Sysbench对Mysql进行基准测试
    yum安装软件时报错libmysqlclient.so.18()(64bit)
    redis启动报错Could not connect to Redis at 127.0.0.1:6379: 由于目标计算机积极拒绝,无法连接。
    cmd 中连接mysql时报'mysql'不是内部或外部命令,也不是可运行的程序或批处理文件
    Mysql远程连接权限
    Git基础教程
    电脑adb命令给智能电视安装APK
    python基础之类
    python基础之函数
    前端之CSS第二部分属性相关
  • 原文地址:https://www.cnblogs.com/tabchanj/p/5696196.html
Copyright © 2011-2022 走看看