当前位置: 首页 > article >正文

Web 站点的欢迎页面

Web 站点的欢迎页面

  • 一、JavaWeb 中的欢迎页
    • 1.Tomcat 的默认欢迎页
    • 2.局部配置欢迎页
  • 二、SpringBoot 中的欢迎页
    • 1.默认欢迎页
    • 2.自定义欢迎页
      • (1) 通过页面跳转控制器方式
      • (2) controller 直接实现方式


一、JavaWeb 中的欢迎页

1.Tomcat 的默认欢迎页

  • 当文件名设置为 index.html 的时候,不需要在 web.xml 文件中进行配置欢迎页面。这是因为小猫咪 Tomcat 服务器已经提前配置好了。
  • 实际上配置欢迎页有两个地方可以配置:
    • 一个是在 webapp 内部的 web.xml 文件中。(在这个地方配置的属于局部配置
    • 一个是在 CATALINA_HOME/conf/web.xml 文件中进行配置。(在这个地方配置的属于全局配置
    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
       	 <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
    
    • Tomcat 服务器的全局欢迎页面是:index.html index.htm index.jsp。如果你一个 web 站点没有设置局部的欢迎页面,Tomcat 服务器就会以 index.html index.htm index.jsp 作为一个 web 站点的欢迎页面。
    • 注意原则:局部优先原则。(就近原则)

2.局部配置欢迎页

  • 第一步:在 IDEA 工具的 web 目录下新建一个文件 login.html
  • 第二步:在 web.xml 文件中进行以下的配置
    <!-- ① 如果欢迎页在根路径下 -->
    <welcome-file-list>
    	<!-- 设置欢迎页面的时候,这个路径不需要以 ”/“ 开始。**并且这个路径默认是从 webapp 的根下开始查找** -->
    	<welcome-file>login.html</welcome-file>
    </welcome-file-list>
    
    <!-- ② 如果欢迎页不在根路径下 -->
    <welcome-file-list>
    	<welcome-file>page1/page2/login.html</welcome-file>
    </welcome-file-list>
    
    <!-- ③设置多个欢迎页面 -->
    <welcome-file-list>
    	<!-- 注意:越靠上的优先级越高。找不到的继续向下找 -->
    	<welcome-file>page1/page2/login1.html</welcome-file>
    	<welcome-file>page1/page2/login2.html</welcome-file>
    </welcome-file-list>
    
    <!-- 设置一个 servlet 为欢迎页面 -->
    <!-- 欢迎页面就是一个资源,可以是静态资源也可以是动态资源 -->
     <welcome-file-list>
        <welcome-file>user/login</welcome-file>
    </welcome-file-list>
    

二、SpringBoot 中的欢迎页

1.默认欢迎页

  • 在 SpringBoot 中,默认的欢迎界面名称是 index.html。并且会在默认的资源路径下查找 index.html 文件。默认配置如下:
    spring:
      web:
        resources:
          static-locations: classpath:/META-INF/resources/, classpath:/resources/, classpath:/static/ , classpath:/public/
    
  • 则页面加载的顺序为如下:
    ① classpath:/META-INF/resources/ 
    ② classpath:/resources/
    ③ classpath:/static/ 
    ④ classpath:/public/
    ⑤ classpathL/templates/(如果使用thymeleaf视图技术的情况)
    

2.自定义欢迎页

(1) 通过页面跳转控制器方式

  • 参考我的博客 ===> SpringBoot中的WebMvcConfigurer 中的第二部分,页面跳转控制器。

(2) controller 直接实现方式

  • 第一步:创建一个 Controller 跳转到目标欢迎页。
    @Controller
    public class IndexController {
        @RequestMapping("/")
        public String login(){
            return "redirect:login.html";
        }
    }
    
  • 第二步:编写欢迎页面。
    在这里插入图片描述
  • 第三步:浏览器地址栏输入地址
    在这里插入图片描述
  • 注意:如果使用了 Thymeleaf 视图技术的话,存放在 templates 目录下的资源是动态资源,没有办法直接访问的,所以不能使用重定向来实现页面的跳转,只能使用转发的方式实现。
  • 还需要注意,动态页面如果要访问必须要经过视图解析器,否则无法访问,所以也不能使用完整路径的转发方式。


http://www.kler.cn/a/229451.html

相关文章:

  • 解决 VSCode 调试时 Python 文件出现相对路径报错问题‘FileNotFoundError’
  • Oracle Dataguard(主库为双节点集群)配置详解(5):将主库复制到备库并启动同步
  • 使用WebdriverIO和Appium测试App
  • 504 Gateway Timeout:网关超时解决方法
  • STM32特殊功能引脚详解文章·STM32特殊功能引脚能当作GPIO使用嘛详解!!!
  • 计算机网络速成
  • MYSQL performance schema详解
  • zk集群--集群同步
  • 麒麟V10系统下离线安装docker-compose
  • 书客/霍尼韦尔/柏曼大路灯哪款好?多维度真实测评!买对不买贵!
  • c#string方法对比
  • c++之说_10|自定义类型 union 联合体
  • 艺术创作和生活的关系
  • 基于亚马逊云科技新功能:Amazon SageMaker Canvas无代码机器学习—以构建货物的交付状态检测模型实战为例深度剖析以突显其特性
  • Qt 字符串类应用与常用基本数据类型
  • MySQL知识点总结(四)——MVCC
  • 【力扣】罗马数字转整数,哈希集合+模拟
  • Git版本管理工具(基础):这一篇基本能满足Git基本的使用需求了!
  • WiFi 6 和WiFi 6e 的核心要点
  • 谷歌免费开放模糊测试框架OSS-Fuzz(物联网、车联网、供应链安全、C/C++)
  • clickhouse计算前后两点间经纬度距离
  • C++结构化绑定
  • GEDepth:Ground Embedding for Monocular Depth Estimation
  • 函数的连续与间断【高数笔记】
  • CAEX 学习记录
  • MATLAB语音去噪系统