springboot以http请求访问本地图片

如下图,本机(服务器)存储的图片想要在浏览器上通过Url地址访问:
在这里插入图片描述

1.上传

实现很简单,只需要利用拦截器将本机地址映射成url路径就行:

@Configuration
public class FilePathConfig implements WebMvcConfigurer {
    @Override
    public void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/upload/**") //虚拟url路径
                .addResourceLocations("file:E:/image/"); //真实本地路径
    }
}

启动程序,输入本机Ip+端口+Url路径(替代了图片本地路径)+图片文件名:
在这里插入图片描述
尝试上传后再访问:

 public static final String host = "http://127.0.0.1:8080/upload/";


    @ApiOperation(value = "上传图片")
    @ApiImplicitParam(name = "file",value = "图片上传",required = true,dataTypeClass = MultipartFile.class,
            allowMultiple = true,paramType = "query")
    @PostMapping(value = "/upload")
    @ResponseBody
    public String insertOrderImg(@RequestParam("file") MultipartFile file) {
        // 文件上传路径
        String location = "E:\\image\\";

        String originalFilename = file.getOriginalFilename();
        String extName = originalFilename.substring(originalFilename.lastIndexOf("."));
        //设置允许上传文件类型
        String suffixList = ".jpg,.png,.ico,.bmp,.jpeg";
        String imgUrl=null;
        // 判断是否包含
        if (suffixList.contains(extName.trim().toLowerCase())) {
            // 保存文件的路径
            String path = location + originalFilename;
            //  spring的transferTo保存文件方法
            try {
                file.transferTo(new File(path));
                imgUrl = host + originalFilename;
            } catch (IOException e) {
                log.info("保存失败");
            }
        }
        return imgUrl;
    }

用knife4j上传图片成功并返回url地址:
在这里插入图片描述
在这里插入图片描述

2.压缩

使用Hutool或Thumbnails
引入依赖

<!--        图像处理依赖,包含了Thumbnails-->
        <dependency>
            <groupId>com.siashan</groupId>
            <artifactId>toolkit-image</artifactId>
            <version>1.1.1</version>
        </dependency>
public static final String host = "http://127.0.0.1:8080/upload/";


    @ApiOperation(value = "上传图片")
    @ApiImplicitParam(name = "file",value = "图片上传",required = true,dataTypeClass = MultipartFile.class,
            allowMultiple = true,paramType = "query")
    @PostMapping(value = "/upload")
    @ResponseBody
    public String insertOrderImg(@RequestParam("file") MultipartFile file) throws IOException {
        // 文件上传路径
        String location = "E:\\image\\";
        String originalFilename = file.getOriginalFilename();
        String extName = originalFilename.substring(originalFilename.lastIndexOf("."));
        //设置允许上传文件类型
        String suffixList = ".jpg,.png,.ico,.bmp,.jpeg";
        String imgUrl=null;
        // 判断是否包含
        if (suffixList.contains(extName.trim().toLowerCase())) {
            BufferedImage image = ImgUtil.read(file.getInputStream());
            int height = image.getHeight();
            int width = image.getWidth();
            // 保存文件的路径
            String path = location + originalFilename;
            // thumbnailator压缩存放路径
            String thumbPath= location+"thumbnailator"+originalFilename;
            //Img压缩存放路径
            String imgPath = location +"img"+ originalFilename;
            String newPath = location +"new"+ originalFilename;
            String shaValue = DigestUtil.sha256Hex(file.getBytes());
            //  spring的transferTo保存文件方法
            try {
                log.info("原图高{},宽{},大小{}KB",height,width,file.getSize()/1024);
                file.transferTo(new File(path));

                //Hutool图像编辑器压缩
                Img img = Img.from(file.getInputStream());
                Image img1 = img.scale(0.5f).setQuality(0.2f).getImg();
                byte[] bytes = ImgUtil.toBytes(img1, ImgUtil.IMAGE_TYPE_JPEG);
                log.info("Hutool压缩后高{},宽{},大小{}KB",img1.getHeight(null),img1.getWidth(null),bytes.length/1024);
                FileUtil.writeBytes(bytes,imgPath);

                //Thumbnails压缩 要读取压缩后图片大小和尺寸必须写后再读,没有Img编辑器压缩方便
                OutputStream outputStream1 = new FileOutputStream(thumbPath);
                Thumbnails.of(file.getInputStream())
                        .scale(0.5f)
                        .outputQuality(0.2f)
                        .toOutputStream(outputStream1);
                outputStream1.close();
                byte[] bytes1 = FileUtil.readBytes(thumbPath);
                BufferedImage read1 = ImgUtil.read(thumbPath);
                log.info("直接压缩高{},宽{},大小{}KB",read1.getHeight(),read1.getWidth(),bytes1.length/1024);

//                //Hutool另一种压缩方法,要读取压缩后图片大小和尺寸必须写后再读 ,没有Img编辑器压缩方便
//                OutputStream outputStream2 = new FileOutputStream(newPath);
//                ImageOutputStream imageOutputStream = ImgUtil.getImageOutputStream(outputStream2);
//                ImgUtil.scale(image, imageOutputStream, 0.5f);
//                ImgUtil.write(image,ImgUtil.IMAGE_TYPE_JPG,imageOutputStream,0.2F);
//                outputStream2.close();
//                byte[] bytes2 = FileUtil.readBytes(newPath);
//                BufferedImage read2 = ImgUtil.read(newPath);
//                log.info("Hutool直接压缩高{},宽{},大小{}KB",read2.getHeight(),read2.getWidth(),bytes2.length/1024);
                imgUrl = host + originalFilename;
            } catch (IOException e) {
                log.info("保存失败");
            }
        }
        return imgUrl;
    }

在这里插入图片描述
在这里插入图片描述

3.同一图片禁止重复

在这里插入图片描述

 public static final String host = "http://127.0.0.1:8080/upload/";

    public static final Map<String,String> imgMap= new ConcurrentHashMap<>();

    @ApiOperation(value = "上传图片")
    @ApiImplicitParam(name = "file",value = "图片上传",required = true,dataTypeClass = MultipartFile.class,
            allowMultiple = true,paramType = "query")
    @PostMapping(value = "/upload")
    @ResponseBody
    public String insertOrderImg(@RequestParam("file") MultipartFile file) throws IOException {
        // 文件上传路径
        String location = "E:\\image\\";
        String originalFilename = file.getOriginalFilename();
        String extName = originalFilename.substring(originalFilename.lastIndexOf("."));
        //设置允许上传文件类型
        String suffixList = ".jpg,.png,.ico,.bmp,.jpeg";
        String imgUrl=null;
        // 判断是否包含
        if (suffixList.contains(extName.trim().toLowerCase())) {
            BufferedImage image = ImgUtil.read(file.getInputStream());
            int height = image.getHeight();
            int width = image.getWidth();
            // 保存文件的路径
            String path = location + originalFilename;
            // thumbnailator压缩存放路径
            String thumbPath= location+"thumbnailator"+originalFilename;
            //Img压缩存放路径
            String imgPath = location +"img"+ originalFilename;
            String newPath = location +"new"+ originalFilename;
            //同一文件SHA256进行哈希运算后值唯一
            String shaValue = DigestUtil.sha256Hex(file.getBytes());
            if (imgMap.containsKey(shaValue)) {
                log.info("重复的SHA{},已上传的文件名{}",shaValue,imgMap.get(shaValue));
                return "已经上传,不可重复";
            }
            imgMap.put(shaValue,originalFilename);
            //  spring的transferTo保存文件方法
            try {
                log.info("原图高{},宽{},大小{}KB",height,width,file.getSize()/1024);
                file.transferTo(new File(path));

                //Hutool图像编辑器压缩
                Img img = Img.from(file.getInputStream());
                Image img1 = img.scale(0.5f).setQuality(0.2f).getImg();
                byte[] bytes = ImgUtil.toBytes(img1, ImgUtil.IMAGE_TYPE_JPEG);
                log.info("Hutool压缩后高{},宽{},大小{}KB",img1.getHeight(null),img1.getWidth(null),bytes.length/1024);
                FileUtil.writeBytes(bytes,imgPath);

                //Thumbnails压缩 要读取压缩后图片大小和尺寸必须写后再读,没有Img编辑器压缩方便
                OutputStream outputStream1 = new FileOutputStream(thumbPath);
                Thumbnails.of(file.getInputStream())
                        .scale(0.5f)
                        .outputQuality(0.2f)
                        .toOutputStream(outputStream1);
                outputStream1.close();
                byte[] bytes1 = FileUtil.readBytes(thumbPath);
                BufferedImage read1 = ImgUtil.read(thumbPath);
                log.info("Thumbnails压缩高{},宽{},大小{}KB",read1.getHeight(),read1.getWidth(),bytes1.length/1024);

//                //Hutool另一种压缩方法,要读取压缩后图片大小和尺寸必须写后再读 ,没有Img编辑器压缩方便
//                OutputStream outputStream2 = new FileOutputStream(newPath);
//                ImageOutputStream imageOutputStream = ImgUtil.getImageOutputStream(outputStream2);
//                ImgUtil.scale(image, imageOutputStream, 0.5f);
//                ImgUtil.write(image,ImgUtil.IMAGE_TYPE_JPG,imageOutputStream,0.2F);
//                outputStream2.close();
//                byte[] bytes2 = FileUtil.readBytes(newPath);
//                BufferedImage read2 = ImgUtil.read(newPath);
//                log.info("Hutool直接压缩高{},宽{},大小{}KB",read2.getHeight(),read2.getWidth(),bytes2.length/1024);
                imgUrl = host + originalFilename;
            } catch (IOException e) {
                log.info("保存失败");
            }
        }
        return imgUrl;
    }

第一次上传成功后继续上传:
在这里插入图片描述
在这里插入图片描述
同一张图片改名后上传:
在这里插入图片描述
同一张图片格式也更改后上传:
在这里插入图片描述

换其它图片上传:
在这里插入图片描述

<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、付费专栏及课程。

余额充值