springboot通过url访问项目外的其他目录下的资源

本文介绍在SpringBoot中如何通过两种方式配置图片资源映射,包括修改application.properties文件及使用Java配置类,使图片能通过指定URL路径访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

第一种方式、在配置文件application.properties,添加配置

资源映射地址为file:D://User/,图片存放的真实路径
spring.resources.static-locations=file:D://User/

资源映射路径为/image/**,你想在url访问的请求路径
spring.mvc.static-path-pattern=/image/**

第二种方式、在代码上添加配置项文件

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;

@Configuration

public class WebMvcConfiguration extends WebMvcConfigurerAdapter {

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {

        //addResourceHandler是指你想在url请求的路径
        //addResourceLocations是图片存放的真实路径
       registry.addResourceHandler("/image/**").addResourceLocations("file:D://User/");
        super.addResourceHandlers(registry);
    }
}

举例说明:

例如1:文件的真实路径是:D://User/ 123.png,访问路径:localhost:8080/image/123.png
如果项目设置根目录:(java为根目录名称)访问地址为localhost:8080/java/image/123.png

例如2:文件真实路径是:D://User/ png/123.png,访问路径:localhost:8080/image/png/123.png
如果项目设置根目录:(java为根目录名称)访问地址为localhost:8080/java/image/png/123.png

上面两种方式,我是比较喜欢第二种,配置多个路径时,第二种相对于第一种配置更方便、简单

<think>好的,用户想在Spring Boot中通过URL访问本地图片的示例代码。首先,我需要回忆一下Spring Boot处理静态资源的方式。默认情况下,静态资源放在`src/main/resources/static`目录下,可以直接通过URL访问。例如,图片放在`static/images`里,可以通过`http://localhost:8080/images/图片名`访问。但用户可能需要访问本地文件系统的图片,而不仅仅是项目内的资源。这时候需要自定义资源映射。 接下来,用户可能需要配置一个资源处理器,将本地文件系统的路径映射到URL上。这可以通过实现`WebMvcConfigurer`接口,并重写`addResourceHandlers`方法来实现。例如,将`file:/path/to/local/images/`映射到`/images/**`的URL路径。这样,用户上传的图片或者存储在项目部的图片就可以通过URL访问了。 另,可能需要考虑跨域问题,特别是在前端应用和Spring Boot后端分离的情况下。这时候需要在配置类中添加`@CrossOrigin`注解或者配置全局的CORS策略。 还要注意安全性,确保用户不能通过URL访问到敏感文件。可能需要设置适当的路径权限,或者对请求进行验证。 然后,代码示例部分需要展示如何配置资源处理器。例如,创建一个配置类,使用`@Configuration`注解,并实现`WebMvcConfigurer`。在`addResourceHandlers`方法中,使用`registry.addResourceHandler`添加处理路径,并通过`addResourceLocations`指定本地路径。需要提醒用户替换实际的本地路径,并注意路径格式是否正确,比如以`file:`开头,并且在Windows系统中使用正斜杠或双反斜杠。 另,可能需要处理图片的存储和访问权限,比如使用`ResourceHttpRequestHandler`,或者通过控制器来处理动态的图片请求。例如,使用`@GetMapping`配合`@ResponseBody`返回图片资源。 可能还需要考虑缓存策略,或者图片的动态生成,比如缩略图等。不过用户的需求看起来是基础的文件访问,所以保持示例简单。 最后,确保引用了相关的Spring Boot文档或官方指南,比如处理静态资源的部分,或者资源处理的配置方法。检查是否有相关的站内引用可以关联,比如引用[1]提到自动配置,可能涉及静态资源的默认处理,而用户需要的是自定义配置,所以需要覆盖默认行为。 总结步骤:配置资源映射,处理本地路径,示例代码,注意事项,相关引用。然后生成相关问题,比如安全性、上传文件、路径问题等。</think>在Spring Boot中通过URL访问本地图片,可通过配置静态资源映射实现。以下是具体步骤和代码示例: ### 1. 基础配置(默认静态资源) 将图片放在默认静态目录下: ```text src/main/resources/static/images/photo.jpg ``` 访问URL: $$ http://localhost:8080/images/photo.jpg $$ ### 2. 自定义本地路径映射(推荐) 创建配置类处理部存储路径: ```java @Configuration public class WebConfig implements WebMvcConfigurer { @Override public void addResourceHandlers(ResourceHandlerRegistry registry) { // Windows示例路径(注意斜杠方向) String winPath = "file:D:/uploaded-images/"; // Linux/Mac示例路径 String linuxPath = "file:/opt/uploads/"; registry.addResourceHandler("/images/**") .addResourceLocations(winPath, linuxPath) .setCachePeriod(3600); } } ``` [^1] ### 3. 控制器动态处理(可选) 对于需要权限验证的场景: ```java @RestController public class ImageController { @GetMapping("/secured/images/{filename:.+}") public ResponseEntity<Resource> getImage(@PathVariable String filename) { Path file = Paths.get("D:/secure-images/" + filename); Resource resource = new UrlResource(file.toUri()); return ResponseEntity.ok() .contentType(MediaType.IMAGE_JPEG) .body(resource); } } ``` ### 4. 跨域配置(若需要) ```java @Configuration public class CorsConfig implements WebMvcConfigurer { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/images/**") .allowedOrigins("http://client-domain.com") .allowedMethods("GET"); } } ``` ### 验证步骤: 1. 在`D:/uploaded-images`放置`test.jpg` 2. 访问`http://localhost:8080/images/test.jpg` 3. 应能看到图片内容
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值