关于根据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把//也转为字符了,然后报错没有协议

相关推荐
IT空门:门主8 小时前
Spring 注入三剑客:@Resource、@Autowired、@RequiredArgsConstructor 到底该用哪个?
java·后端·spring
南部余额8 小时前
Spring WebClient 从入门到精通
java·后端·spring
摇滚侠8 小时前
Spring 零基础入门到进阶 基于注解管理 Bean 38-43
xml·java·后端·spring·intellij-idea
云烟成雨TD9 小时前
Spring AI 1.x 系列【47】 MCP Annotations 模块
java·人工智能·spring
Flittly11 小时前
【AgentScope Java新手村系列】(3)工具系统
java·spring boot·spring
云烟成雨TD12 小时前
Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers
人工智能·spring·docker
Flittly12 小时前
【AgentScope Java新手村系列】(2)第一个Agent-基础对话
java·spring boot·spring·ai
摇滚侠13 小时前
Spring MVC 不是一个单独的框架,是 Spring 框架的一个模块
java·spring·mvc
小刘|14 小时前
Spring WebFlux + AI 流式输出深度解析:Spring AI 与 LangChain4j 效果差异溯源
java·后端·spring
worilb14 小时前
Spring Cloud 学习与实践(8):Spring Cloud Gateway 统一入口、路由转发与双重跨域故障演练
学习·spring·spring cloud