关于根据url下载文件之空格符报错

前言

描述:本文主要是记录后端代码根据url获取文件时发生报错的解决方案

一、遇到的报错

java 复制代码
Serverreturned HTTPresponse code: 400 for URL

分析:由于我上传的Excel文件中存在空格符,导致代码在获取文件时发生报错

1、项目初始代码

java 复制代码
public Workbook generateExcelObject(String fileUrl) {
    try {
        // 获取文件数据
        URL url = new URL(fileUrl);
        InputStream inputStream = url.openStream();
        if (!(inputStream.markSupported())) {
            inputStream = new PushbackInputStream(inputStream, 8);
        }

        // 生成excel对象
        Workbook book = WorkbookFactory.create(inputStream);
        return book;
    } catch (Exception e) {
        e.printStackTrace();
        return null;
    }
}

二、解决方案

1、直接替换

java 复制代码
	URL url = new URL(fileUrl.replace(" ", "%20"));

2、使用 URLEncoder.encode

java 复制代码
        // 对文件链接中的空格进行URL编码处理
        String encodedUrl = URLEncoder.encode(fileUrl, "UTF-8");

总结

实际测下来,方法1 可以成功,方法2不行,依然会在 InputStream inputStream = url.openStream(); 发生报错。原因是方法2把//也转为字符了,然后报错没有协议

相关推荐
jian110582 小时前
JAVA Spring MVC+Mybatis Spring MVC的工作流程*,多表连查
java·spring·mvc
设计师小聂!4 小时前
spring cloud alibaba-Geteway详解
java·spring·spring cloud
白日依山尽yy4 小时前
SpringMVC04所有注解按照使用位置划分| 按照使用层级划分(业务层、视图层、控制层)
spring·mvc
爱吃烤鸡翅的酸菜鱼4 小时前
【Spring Boot】配置实战指南:Properties与YML的深度对比与最佳实践
java·spring boot·后端·spring·java-ee·intellij-idea
鸠。5 小时前
苍穹外卖05 Redis常用命令&&在Java中操作Redis_Spring Data Redis使用方式&店铺营业状态设置
java·redis·spring
白开水不加冰15 小时前
Spring的BeanFactory和FactoryBean的区别
java·后端·spring
北漂老男孩21 小时前
Spring 框架核心机制深度解析【AI模型互搏生成】
java·后端·spring
blammmp21 小时前
Spring Cloud:Gateway(统一服务入口)
spring·spring cloud·gateway
攒了一袋星辰1 天前
Spring是如何实现scope作用域支持
java·后端·spring
小黑屋说YYDS1 天前
Spring Validation校验
java·后端·spring