SpringBoot配置url访问本地图片

本文介绍了如何在SpringBoot应用中配置URL以访问本地图片,通过修改yml文件和创建WebConfig实现WebMvcConfigurer接口,实现了从指定存储路径加载图片并展示的功能。

非常简单,首先配置yml文件

server:
  port: 8080
  servlet:
    context-path: /demo/
    
picture:
  # 图片访问路径
  show: /show/**
  # 本地映射,图片真实存放路径
  up-path: D:/MyPhoto/picture/

然后创建WebConfig实现WebMvcConfigurer

import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.ResourceHandlerRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

/**
 * @Description TODO
 * @Author admin
 * @Date 2020/12/10
 */
@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Value("${picture.show}")
    private String showPath;
    @Value("${picture.up-path}")
    private String upPath;

    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler(showPath).addResourceLocations("file:" + upPath);
    }

}

这样就可以了,我们按照yml配置的的存储路径放两张照片试一哈。
在这里插入图片描述
在这里插入图片描述

启动项目,打开浏览器,效果如下:
在这里插入图片描述
在这里插入图片描述

<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. 应能看到图片内容
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值