springboot静态资源目录访问,及自定义静态资源路径,index页面的访问
创始人
2024-05-16 16:22:48
0

springboot静态资源目录访问,及自定义静态资源路径,index页面的访问

  • 静态资源目录的访问位置
  • 静态资源访问测试
  • 自定义静态资源路径和静态资源请求映射
  • web首页的访问
    • 自定义静态资源请求映射影响index.html首页的访问的**解决方案**:
      • 1.取消自定义静态资源映射
      • 2.编写controller,将index.html的请求截获

静态资源目录的访问位置

默认情况下,Spring Boot 从名为 /static (or /public or /resources or /META-INF/resources) 在类路径中或从根目录来访问静态资源。
访问 : 当前项目根路径/ + 静态资源名

原理: 静态映射/**
请求进来,先去找Controller看能不能处理。不能处理的所有请求又都交给静态资源处理器。静态资源如果找不到则响应404页面

可以通过修改application.properties文件或者application.yaml配置文件,来修改默认的静态资源访问路径及静态资源的默认存放路径,如下:

properties:

spring.mvc.static-path-pattern=/resources/**

yaml:

spring:mvc:static-path-pattern: "/resources/**"

静态资源访问测试

首先,创建一个springboot的web项目,然后按照上面静态资源存放的位置,分别在类路径下创建对应的文件夹,然后启动springboot,在url中输入请求参数(资源名),来去访问对应的静态资源。

在类路径下,分别创建 /static (or /public or /resources or /META-INF/resources)这几个静态资源目录,然后存放一些图片,用于待会儿测试访问:
在这里插入图片描述

启动服务,输入请求参数:

http://localhost:8080/kl.jpg

在这里插入图片描述

http://localhost:8080/kq.jpg

在这里插入图片描述

http://localhost:8080/ddly.jpg

在这里插入图片描述

http://localhost:8080/OIP-C.jpg

在这里插入图片描述

总结:静态资源的访问即为 当前项目根路径/ + 静态资源名,springboot底层已经为我们封装好了。

自定义静态资源路径和静态资源请求映射

创建application.yaml

spring:# 修改请求映射mvc:static-path-pattern: /res/**# 修改静态资源目录web:resources:static-locations: [classpath:/images/]

在类路径下,创建自己刚刚自定义的静态资源目录 images,并且存放一张图片,用于待会儿测试

在这里插入图片描述

修改完毕后,再次启动服务

发现通过之前的请求 http://localhost:8080/kq.jpg 已经无法访问到静态资源了

在这里插入图片描述

输入刚刚修改的请求映射http://localhost:8080/res/kq.jpg静态资源成功访问

在这里插入图片描述

web首页的访问

它首先在配置的静态内容位置中查找文件。如果找到index.html,则将其作为首页,如果没找到再去找对应的controller中是否有index的映射配置,找到的话则作为首页,如果都找不到则404。

注意:当自定义静态资源映射和静态资源目录时,访问首页的请求会失效,需要在请求中添加静态资源映射前缀,以及在自定义静态资源目录中需要有index.html.

测试:我在刚刚自定义的静态资源目录中添加了一个index.html
在这里插入图片描述

访问:http://localhost:8080/index.html,报404,原因是我上面自定义了静态资源映射
在这里插入图片描述

访问http://localhost:8080/res/index.html,成功访问
在这里插入图片描述
小结:自定义静态资源请求映射会影响index.html首页的访问。

自定义静态资源请求映射影响index.html首页的访问的解决方案

1.取消自定义静态资源映射

修改application.yaml的配置信息:

spring:# 修改请求映射
#  mvc:
#    static-path-pattern: /res/**# 修改静态资源目录web:resources:static-locations: [classpath:/images/]

启动服务,再次访问:http://localhost:8080/index.html,成功访问

在这里插入图片描述

2.编写controller,将index.html的请求截获

通过controller中的请求处理,将截获的/index.html请求转换为/资源路径/index.html,就是页面重定向。

package com.robin.boot.controller;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.io.IOException;@RestController
public class StaticController {@RequestMapping("/index.html")public String say(HttpServletResponse resp) throws IOException {resp.sendRedirect("/res/index.html");return null;}
}

输入http://localhost:8080/index.html,成功访问

在这里插入图片描述


相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
AWSECS:哪种网络模式具有... 使用AWS ECS中的awsvpc网络模式来获得最佳性能。awsvpc网络模式允许ECS任务直接在V...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...