解决springboot 无法配置多个静态路径的问题

目录
  • springboot 无法配置多个静态路径
    • 需要在启动类里加一段代码如下:
  • springboot静态路径配置遇到的坑
    • 按照网上一些博客的说法
    • 解决方法

springboot 无法配置多个静态路径

默认static路径是可以访问的,

对接天猫精灵需要额外的放开一个目录aligenie,供天猫精灵端访问,且路径名称无法更改。

这就导致了一个问题,默认识别的静态路径META-INF/resources / resources / static / public 都是spring boot 认为静态资源应该放置的位置,会自动去寻找静态资源。无法识别aligenie路径。

需要在启动类里加一段代码如下:

?

1

2

3

4

@Override

public void addResourceHandlers(ResourceHandlerRegistry registry) {

registry.addResourceHandler("/aligenie/**").addResourceLocations("classpath:/aligenie/");

}

springboot静态路径配置遇到的坑

用springboot做一个项目,遇到一个情况是前端要展示服务器保存的图片,这时候涉及到一个静态路径配置的问题,踩到了一个坑

因为springboot是自带tomcat的,所以我们没必要去改变自己tomcat的设置,只需要在properties.yml里进行配置或者继承WebMvcConfigurationSupport类去写一个配置类,其中yml配置的方法可以自行去找,网上一搜一大把,这里说下用配置类遇到的一个坑

按照网上一些博客的说法

?

1

2

3

4

5

6

7

8

9

@Configuration

public class UploadConfiguration extends WebMvcConfigurationSupport {

@Override

protected void addResourceHandlers(ResourceHandlerRegistry registry) {

registry.addResourceHandler("/upload/**")//这个将应用到url中

.addResourceLocations("file:///");//这里填的是图片的绝对父路径

super.addResourceHandlers(registry);

}

}

这样跑了一下之后发现,虽然图片是可以直接通过url访问到了,但是html、js等其他静态资源(和图片不在同一个文件夹下)访问不到了...

解决方法

虽然现在大家都会前后端分离开发,不会遇到这样的问题,但是既然遇到了,还是得想办法解决一下的,初步猜测的话,是因为配置类覆盖了原来的默认静态路径,导致了新配置起效但是原来的访问不了的情况,所以我们再手动把原来的路径添加进来

?

1

2

3

4

5

6

7

8

9

10

11

12

@Configuration

public class UploadConfiguration extends WebMvcConfigurationSupport {

@Override

protected void addResourceHandlers(ResourceHandlerRegistry registry) {

registry.addResourceHandler("/**")

.addResourceLocations("file:///");//这里是所有静态资源的父文件夹绝对路径,一般是webapps文件夹的路径

super.addResourceHandlers(registry);

registry.addResourceHandler("/upload/**")//这个将应用到url中

.addResourceLocations("file:///");//这里填的是图片的绝对父路径

super.addResourceHandlers(registry);

}

}

这样问题就解决了!

最后再提一下,file:/// 这里的斜杠为什么是三条,网上有教程说是要进行转义,但是经过实测一条和三条都是没区别的,有点玄学~

以上为个人经验,希望能给大家一个参考,也希望大家多多支持服务器之家。

原文链接:https://blog.csdn.net/qq_31949853/article/details/85148841

本文链接:https://my.lmcjl.com/post/9249.html

展开阅读全文

4 评论

留下您的评论.